时间:2021-07-01 10:21:17 帮助过:23人阅读
字符数据类型
字符数据类型存储在字符串中的字符 (字母或数字) 数据。
最常用的字符数据类型是 VARCHAR2,它是用于存储字符数据的最有效的选项。
与字符编码模式相对应的字节值,一般称为 字符集或 代码页。 数据库字符集是在数据库创建时建立的。
字符集的例子有 7 位 ASCII 码、 EBCDIC码、和 Unicode utf-8。
字符数据类型的长度语义可以以字节或字符为单位。
字节语义将字符串视为一个字节序列。 这是字符数据类型的默认值。
字符语义将字符串视为字符序列。 一个字符在技术上是数据库字符集的编码点。
VARCHAR2 、CHAR NCHAR、NVARCHAR2
Oracle Database compares VARCHAR2 values using nonpadded comparison semantics and compares CHAR values using blank-padded comparison semantics.
Oracle 数据库将使用非填充比较语义来比较 VARCHAR2 值,而使用空白填充比较语义来比较 CHAR 值。
VARCHAR2 |
CHAR |
The VARCHAR2 data type stores variable-length character literals. VARCHAR2 数据类型存储变长字符文本。 The terms literal and constant value are synonymous and refer to a fixed data value. 文本和常量值这两个术语是同义词,指的是一个固定的数据值 |
CHAR stores fixed-length character strings. CHAR 存储固定长度的字符串 |
VARCHAR2(25):表示该列中存储的名字最多可以长达25个字节 |
当创建一个有CHAR 列的表时,需要为该列指定一个字符串长度。默认值是 1 个字节。
数据库使用空格填充到指定的长度的值。 |
NVARCHAR2 |
NCHAR |
NVARCHAR2 和 NCHAR 数据类型存储 Unicode 字符数据。 Unicode 是一种通用的编码字符集,可以将任何语言的信息存储在一种字符集中。 当您创建数据库时,指定国家字符集。 NCHAR 和 NVARCHAR2 数据类型的字符集必须是 AL16UTF16 或 UTF8。 这两种字符集都使用 Unicode 编码。 当您创建一个有 NCHAR 或 NVARCHAR2 列的表时,其最大大小始终是字符长度语义。 对于 NCHAR 或 NVARCHAR2,字符长度语义是默认的,也是唯一的长度语义。 |
The NCHAR and NVARCHAR2 data types store Unicode character data. Unicode is a universal encoded character set that can store information in any language using a single character set. NCHAR stores fixed-length character strings that correspond to the national character set, whereas NVARCHAR2 stores variable length character strings. You specify a national character set when creating a database. The character set of NCHAR and NVARCHAR2 data types must be either AL16UTF16 or UTF8. Both character sets use Unicode encoding. When you create a table with an NCHAR or NVARCHAR2 column, the maximum size is always in character length semantics. Character length semantics is the default and only length semantics for NCHAR or NVARCHAR2. |
NVARCHAR2 存储可变长度的字符串 |
NCHAR存储对应于国家字符集的固定长度字符串 |
Numeric Data Types
数字数据类型
Oracle 数据库的数字数据类型存储固定和浮点数字、零、或无穷。
某些数值类型也可以存储未定义操作的结果值,叫做"非数字"或 NAN。
Oracle 数据库以变长格式存储数字数据。用科学计数法存储值,其中一个字节用于存储指数。
数据库使用最多 20 个字节存储尾数,即浮点数的有效位数部分。
Oracle 数据库不会存储前导零和结尾零。
NUMBER Data Type
NUMBER 数据类型存储固定和浮点数字。
数据库可以存储几乎任何规模的数字。
此数据保证在运行 Oracle 数据库的不同操作系统之间可移植。
大多数情况下,当您必须存储数值数据时,推荐使用 NUMBER 数据类型。
按 NUMBER(p,s)的形式定义定点数,p 和 s 有以下特征:
精度 Precision |
he precision specifies the total number of digits. 精度指定数字的总长度。 If a precision is not specified, then the column stores the values exactly as provided by the application without any rounding. 如果不指定精度,则列按应用程序提供的数据存储值,不作任何舍入。 |
小数位数 Scale |
The scale specifies the number of digits from the decimal point to the least significant digit. 小数位数指从十进制的小数点到最小有效数字的位数。 Positive scale counts digits to the right of the decimal point up to and including the least significant digit. 正小数位数从小数点向右计数直至最小有效位。 Negative scale counts digits to the left of the decimal point up to but not including the least significant digit. 负小数位数从小数点向左计数直至(但不包括)最小有效数字。 If you specify a precision without a scale, as in NUMBER(6), then the scale is 0. 如果您指定了精度但没有指定小数位数,如 NUMBER(6),那么小数位数为 0。 |
Floating-Point Numbers
Oracle 数据库为浮点数提供了两种互斥的数值数据类型: BINARY_FLOAT和 BINARY_DOUBLE。
这两种类型支持所有 NUMBER 数据类型提供的基本功能。
然而,相比 NUMBER使用十进制精度,BINARY_FLOAT 和BINARY_DOUBLE 使用二进制精度,可以使算术计算更快并且通常可以降低存储需求。
BINARY_FLOAT 和 BINARY_DOUBLE 是近似数字数据类型。
它们存储十进制的值的近似表示,而不是精确的表示形式。
例如值 0.1不能用BINARY_DOUBLE 或 BINARY_FLOAT 完全精确地表示。他们经常用于科学计算。
其行为类似于 Java 或 XMLSchema 中的 FLOAT 和 DOUBLE 数据类型。
Datetime Data Types
日期时间数据类型
Datetime Data Types
The datetime data types are DATE and TIMESTAMP. Oracle Database provides comprehensive time zone support for time stamps.
日期时间数据类型包括 DATE和 TIMESTAMP。Oracle 数据库为时间戳提供全面的时区支持。
DATE Data Type |
The DATE data type stores date and time. Although datetimes can be represented in character or number data types, DATE has special associated properties. DATE 数据类型存储日期和时间。尽管日期时间可以用字符或数字数据类型表示,DATE 具有特殊的相关属性。
The database stores dates internally as numbers. Dates are stored in fixed-length fields of 7 bytes each, corresponding to century, year, month, day, hour, minute, and second. 数据库在内部将日期存储为数字。日期被存储为固定长度的域,共 7 个字节,分别对应世纪、 年、 月、 日、 小时、分、和秒。
Note:
数据库根据指定的 格式模型显示日期。
格式模型是一个描述在字符串中的日期时间格式的字符文字。标准的日期格式是 DD-MON-RR,它会以 01-JAN-09 的形式显示日期。
RR类似于 YY (年的最后两位),但返回值的世纪值会因指定的两位年份及本年度的最后两位不同而不同
假设在 1999 年,数据库显示为 01-JAN-09。如果日期格式使用 RR,那么 09 指的是 2009,而如果格式使用 YY,那么 09 指的是 1909。您可以更改实例或会话级别的默认日期格式
Oracle 数据库以 24 小时制格式存储时间 — — HH:MI:SS。如果不输入的任何时间部分,那么默认情况下,日期字段中的时间是凌晨 00: 00: 00,如果只输入了时间,则日期部分默认为当月的第一天。 |
TIMESTAMP Data Type |
TIMESTAMP 数据类型是日期数据类型的扩展
除了存储在 DATE 数据类型的信息,它同时还存储秒的小数部分。
TIMESTAMP 数据类型对于存储精确时间的值很有用,比如那些必须跟踪事件顺序的应用程序。
DATETIME 数据类型 TIMESTAMP WITH TIME ZONE 和TIMESTAMP WITH LOCAL TIME ZONE 能感知时区。
人气教程排行
|