ORACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型、数字类型、日期类型、LOB类型、LONG RAW& RAW类型、ROWID & UROWID类型在讲叙字符串类型前,先要讲一下编码字符串类型的数据可依编码方式分成数据库字符集(CHAR/VARCHAR2/CLOB/LONG)和国际字符集(NCHAR/NVARCHAR2/NCLOB)两种数据库中的字符串数据都通过字符集将字符转换为数字后(二进制),才存储到数据块中通过不同的编码集转换,即便是相同的字符,也可能会转换成不同的二进制编码这也是产生乱码的原因数据库的编码格式一般是在创建数据库时指定的当然也可以修改数据库的编码查看数据库视图所包含的数据类型:SELECT * FROM DBA_TYPES WHERE OWNER IS NULL.具体细节情况参见Oracle® Database SQL Language Quick Reference 10/11g 或官方文档 一 字符串类型 字符串数据类型还可以依据存储空间分为固定长度类型(CHAR/NCHAR) 和可变长度类型(VARCHAR2/NVARCHAR2)两种. 所谓固定长度:是指虽然输入的字段值小于该字段的限制长度,但是实际存储数据时,会先自动向右补足空格后,才将字段值的内容存储到数据块中。
这种方式虽然比较浪费空间,但是存储效率较可变长度类型要好同时还能减少数据行迁移情况发生所谓可变长度:是指当输入的字段值小于该字段的限制长度时,直接将字段值的内容存储到数据块中,而不会补上空白,这样可以节省数据块空间1.1:CHAR类型 CHAR(size [BYTE | CHAR])CHAR类型,定长字符串,会用空格填充来达到其最大长度非NULL的CHAR(12)总是包含12字节信息CHAR字段最多可以存储2,000字节的信息如果创建表时,不指定CHAR长度,则默认为1另外你可以指定它存储字节或字符,例如 CHAR(12 BYTYE) CHAR(12 CHAR).一般来说默认是存储字节,你可以查看数据库参数NLS_LENGTH_SEMANTICS的值SQL Code1. SQL> show parameter nls_length_semantics;2. 3. NAME TYPE VALUE4. ------------------ ----------- -----------------5. 6. nls_length_semantics string BYTE7. 8. eg:9. 10. CREATE TABLE TEST11. 12. (13. 14. NAME_OLD CHAR(10),15. 16. NAME_NEW CHAR(10 CHAR)17. 18. )19. 20. INSERT INTO TEST21. 22. ( NAME_OLD, NAME_NEW)23. 24. SELECT 'ABCDEFGHIJ' , '你清除字节与字符' FROM DUAL;25. 26. COMMIT;27. 28. INSERT INTO TEST29. 30. ( NAME_OLD, NAME_NEW)31. 32. SELECT '你清除字节与字符' , 'ABCDEFGHIJ' FROM DUAL;33. 34. ORA-12899: 列 "SYS"."TEST"."NAME_OLD" 的值太大 (实际值: 24, 最大值: 10) 注意:数据库的NLS_CHARACTERSET 为AL32UTF8,即一个汉字占用三到四个字节。
如果NLS_CHARACTERSET为ZHS16GBK,则一个字符占用两个字节如果串的长度小于或等于250(0x01~0xFA), Oracle 会使用1 个字节来表示长度对于所有长度超过250 的串,都会在一个标志字节0xFE 后跟有两个字节来表示长度因此,如果有一个包含“Hello World”的VARCHAR2(80),则在块中可能如图12.-1 所示1.2: NCHAR类型这是一个包含UNICODE格式数据的定长字符串NCHAR字段最多可以存储2,000字节的信息它的最大长度取决于国家字符集另外查询时,如果字段是NCHAR类型,则需要如下书写SELECT translated_description FROM product_descriptionsWHERE translated_name = N'LCD Monitor 11/PM';1.3 VARCHAR类型不要使用VARCHAR数据类型使用VARCHAR2数据类型虽然VARCHAR数据类型目前是VARCHAR2的同义词,VARCHAR数据类型将计划被重新定义为一个单独的数据类型用于可变长度的字符串相比,具有不同的比较语义。
1.4: VARCHAR2类型变长字符串,与CHAR类型不同,它不会使用空格填充至最大长度VARCHAR2最多可以存储4,000字节的信息1.5: NVARCHAR2类型这是一个包含UNICODE格式数据的变长字符串 NVARCHAR2最多可以存储4,000字节的信息 二. 数字类型 2.1 NUMBER类型NUMBER(P,S)是最常见的数字类型,可以存放数据范围为10^130~10^126(不包含此值),需要1~22字节(BYTE)不等的存储空间P 是Precison的英文缩写,即精度缩写,表示有效数字的位数,最多不能超过38个有效数字S是Scale的英文缩写,可以使用的范围为-84~127Scale为正数时,表示从小数点到最低有效数字的位数,它为负数时,表示从最大有效数字到小数点的位数下面是官方文档的示例Actual DataSpecified AsStored As123.89NUMBER123.89123.89NUMBER(3)124123.89NUMBER(6,2)123.89123.89NUMBER(6,1)123.9123.89NUMBER(3)124123.89NUMBER(4,2)exceeds precision123.89NUMBER(6,-2)100.01234NUMBER(4,5).01234.00012NUMBER(4,5).00012.000127NUMBER(4,5).00013.0000012NUMBER(2,7).0000012.00000123NUMBER(2,7).00000121.2e-4NUMBER(2,5)0.000121.2e-5NUMBER(2,5)0.000012.2 INTEGER类型INTEGER是NUMBER的子类型,它等同于NUMBER(38,0),用来存储整数。
若插入、更新的数值有小数,则会被四舍五入例如:CREATE TABLE TEST(ID INTEGER)查看表TEST的DDL定义如下所示CREATE TABLE "SYS"."TEST"( "ID" NUMBER(*,0)) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGINGSTORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)TABLESPACE "SYSTEM" ;INSERT INTO TESTSELECT 12.34 FROM DUAL;INSERT INTO TESTSELECT 12.56 FROM DUAL;SQL> SELECT * FROM TEST;ID----------12132.3 浮点数浮点数可以有一个十进制数点任何地方从第一个到最后一个数字,或者可以在所有有没有小数点。
指数可能(可选) 用于以下数量增加的范围 (例如, 1.777e-20)刻度值不适用于浮点数字,因为可以显示在小数点后的位数的数量不受限制二进制浮点数不同数量的值由 Oracle 数据库内部存储的方式使用小数精度数存储值完全相同号码存储范围和数量由支持的精度内的所有文本正是因为使用小数精度(数字 0 到 9) 表示文本存储文本使用二进制精度 (数字 0 和 1) 存储二进制浮点数这种存储方案不能代表所有确切地使用小数精度的值频繁地,将值从十进制转换为二进制的精度时出现的错误时撤消值回从二进制转换为十进制精度在字面 0.1 是一个这样的例子Oracle 数据库提供了专为浮点数的两种数值数据类型:BINARY_FLOATBINARY_FLOAT 是 32 位、 单精度浮点数字数据类型可以支持至少6位精度,每个 BINARY_FLOAT 的值需要 5 个字节,包括长度字节BINARY_DOUBLEBINARY_DOUBLE 是为 64 位,双精度浮点数字数据类型每个 BINARY_DOUBLE 的值需要 9 个字节,包括长度字节在数字的列中,浮点数有小数精度在 BINARY_FLOAT 或 BINARY_DOUBLE 的列中,浮点数有二进制的精度。
二进制浮点数支持的特殊值无穷大和 NaN (不是数字)您可以指定列在表 2-4 范围内的浮点数"数字文本"中定义了用于指定浮点数的格式Table 2-3 Floating Point Number LimitsValueBinary-FloatBinary-DoubleMaximum positive finite value3.40282E+38F1.79769313486231E+308Minimum positive finite value1.17549E-38F2.22507485850720E-3082.5 FLOAT类型FLOAT类型也是NUMBER的子类型Float(n),数 n 指示位的精度,可以存储的值的数目N 值的范围可以从 1 到 126若要从二进制转换为十进制的精度,请将 n 乘以 0.30103要从十进制转换为二进制的精度,请用 3.32193 乘小数精度126 位二进制精度的最大值是大约相当于 38 位小数精度 三. 日期类型日期类型用于存储日期数据,但是并不是使用一般的格式(2012-08-08)直接存储到数据库的3.1 DATE类型DATE是最常用的数据类型,日期数据类型存储日期和时间信息。
虽然可以用字符或数字类型表示日期和时间信息,但是日期数据类型具有特殊关联的属性为每个日期值,Oracle 存储以下信息: 世纪、 年、 月、 日期、 小时、 分钟和秒一般占用7个字节的存储空间3.2 TIMESTAMP类型这是一个7字节或12字节的定宽日期/时间数据类型它与DATE数据类型。