ORACLE数据类型占⽤的字节数数据类型参数描写
char(n)n=1 to 2000字节
定长字符串,n字节长,如果不指定长度,缺省为1个字节长(⼀个汉字为2字节)
varchar2(n)
n=1 to 4000字节可变长的字符串,具体定义时指明最⼤长度n,
这种数据类型可以放数字、字母以及ASCII码字符集(或者EBCDIC等数据库系统接管的字符集标准)中的所有符号。
如果数据长度没有到达最⼤值n,Oracle 8i会依据数据⼤⼩主动调节字段长度,
如果你的数据前后有空格,Oracle 8i会主动将其删去。VARCHAR2是最常⽤的数据类型。
可做索引的最⼤长度3209。
number(m, n) m=1 to 38
n=-84 to 127
可变长的数值列,容许0、正值及负值,m是所有有效数字的位数,n是⼩数点以后的位数。
如:number(5,2),则这个字段的最⼤值是99,999,如果数值越过了位数限制就会被截取多余的位数。
如:number(5,2),但在⼀⾏数据中的这个字段输⼊575.316,则真正保存到字段中的数值是575.32。
如:number(3,0),输⼊575.316,真正保存的数据是575。
date⽆从公元前4712年1⽉1⽇到公元4712年12⽉31⽇的所有合法⽇期,
Oracle 8i其实在内部是按7个字节来保存⽇期数据,在定义中还包含⼩时、分、秒。缺省格局为DD-MON-YY,如07-11⽉-00 表⽰2000年11⽉7⽇。
long⽆可变长字符列,最⼤长度限制是2GB,⽤于不须要作字符串搜索的长串数据,如果要进⾏字符搜索就要⽤varchar2类型。
long是⼀种较⽼的数据类型,将来会逐渐被BLOB、CLOB、NCLOB等⼤的对象数据类型所取代。
字符串长度和字节raw(n)n=1 to 2000可变长⼆进制数据,在具体定义字段的时候必需指明最⼤长度n,Oracle 8i⽤这种格局来保存较⼩的图形⽂件或带格局的⽂本⽂件,如Miceosoft Word⽂档。
raw是⼀种较⽼的数据类型,将来会逐渐被BLOB、CLOB、NCLOB等⼤的对象数据类型所取代。
long raw⽆可变长⼆进制数据,最⼤长度是2GB。Oracle 8i⽤这种格局来保存较⼤的图形⽂件或带格局的⽂本⽂件,如Miceosoft Word⽂档,以及⾳频、视频等⾮⽂本⽂件。
在同⼀张表中不能同时有long类型和long raw类型,long raw也是⼀种较⽼的数据类型,将来会逐渐被BLOB、CLOB、NCLOB等⼤的对象数据类型所取代。
blob
clob nclob ⽆
三种⼤型对象(LOB),⽤来保存较⼤的图形⽂件或带格局的⽂本⽂件,如Miceosoft Word⽂档,以及⾳
频、视频等⾮⽂本⽂件,最⼤长度是4GB。
LOB有⼏种类型,取决于你使⽤的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保
存。
可以实⾏读取、存储、写⼊等特别操作。
bfile⽆在数据库外部保存的⼤型⼆进制对象⽂件,最⼤长度是4GB。
这种外部的LOB类型,通过数据库记载变⾰情况,但是数据的具体保存是在数据库外部进⾏的。Oracle 8i可以读取、查询BFILE,但是不能写⼊。
⼤⼩由操作系统决议。
类型如下:
字段类型中⽂说明限制条件其它说明
CHAR 固定长度字符串最⼤长度2000 bytes
VARCHAR2 可变长度的字符串最⼤长度4000 bytes 可做索引的最⼤长度749
NCHAR 根据字符集⽽定的固定长度字符串最⼤长度2000 bytes
NVARCHAR2 根据字符集⽽定的可变长度字符串最⼤长度4000 bytes
DATE ⽇期(⽇-⽉-年) DD-MM-YY(HH-MI-SS)长度7 bytes ⽆千⾍问题
LONG 超长字符串最⼤长度2G(231-1)⾜够存储⼤部头著作
RAW 固定长度的⼆进制数据最⼤长度2000 bytes 可存放多媒体图象声⾳等
LONG RAW 可变长度的⼆进制数据最⼤长度2G 同上
BLOB ⼆进制数据最⼤长度4G
CLOB 字符数据最⼤长度4G
NCLOB 根据字符集⽽定的字符数据最⼤长度4G
BFILE 存放在数据库外的⼆进制数据最⼤长度4G
ROWID 数据表中记录的唯⼀⾏号 10 bytes ********.****.****格式,*为0或1
NROWID ⼆进制数据表中记录的唯⼀⾏号最⼤长度4000 bytes
NUMBER(P,S) 数字类型 P为整数位,S为⼩数位
NUMBER最多占⽤22个字节,最⼤可以保存38个⼗进制位.
--------------------------------------------------------------------------------------------------------------------------------------------Date(长度 7 类型 12)
col dump_date form. a35
col real_date form. a35
select dump(last_ddl_time) dump_date,
to_char(last_ddl_time,'yyyy-mm-dd hh24:mi:ss') real_date
from user_objects
where rownum=1;
DUMP_DATE REAL_DATE
----------------------------------- ---------------------
Typ=12 Len=7: 120,102,4,13,16,48,53 2002-04-13 15:47:52
世纪 120 - 100 = 20 世纪和年份加100后存储
年份 102 - 100 = 2
⽉份 4 ⽉份和⽇期按原值存储
⽇期 13
⼩时 16 - 1 = 15 时间均加1后存储
分钟 48 - 1 = 47
秒 53 - 1 = 52
--------------------------------------------------------------------------------
Number(类型 2)
<[长度]>,符号位/指数数字1,数字2,数字3,......,数字20
正数:指数=数字1 - 193 (最⾼位为1是代表正数)
负数:指数=62 - 第⼀字节
数字1是最⾼有效位
正数:加1存储
负数:被101减,如果总长度⼩于21个字节,最后加⼀个102(是为了排序的需要)
所存储的数值计算⽅法为:
把下⾯计算的结果加起来:
每个数字乘以100^(指数-N) (N是有效位数的顺序位,第⼀个有效位的N=0)
例:
select dump(123456.789) from dual;
DUMP(123456.789)
-------------------------------
Typ=2 Len=6: 195,13,35,57,79,91
指数 195 - 193 = 2
数字1 13 - 1 = 12 *1002-0 120000
数字2 35 - 1 = 34 *1002-1 3400
数字3 57 - 1 = 56 *1002-2 56
数字4 79 - 1 = 78 *1002-3 .78
数字5 91 - 1 = 90 *1002-4 .009
123456.789
select dump(-123456.789) from dual;
DUMP(-123456.789)
----------------------------------
Typ=2 Len=7: 60,89,67,45,23,11,102
指数 62 - 60 = 2(最⾼位是0,代表为负数)
数字1 101 - 89 = 12 *1002-0 120000
数字2 101 - 67 = 34 *1002-1 3400
数字3 101 - 45 = 56 *1002-2 56
数字4 101 - 23 = 78 *1002-3 .78
数字5 101 - 11 = 90 *1002-4 .009
123456.789(-)
现在再考虑⼀下为什么在最后加102是为了排序的需要,-123456.789在数据库中实际存储为
60,89,67,45,23,11
⽽-123456.78901在数据库中实际存储为
60,89,67,45,23,11,91
可见,如果不在最后加上102,在排序时会出现-123456.789<-123456.78901的情况。
-
-------------------------------------------------------------------------------------------------------------------------------------------number类型的数字存储所占⽤的空间,是跟实际数字的⼤⼩有关系的,并不是固定的长度!dump返回的那⼀串东西分别表⽰的是什么意思?
typ 数据类型
len 数据长度
后⾯紧跟的是真实数据存储
⽐如
SQL> select dump(0) from dual;
DUMP(0)
----------------
Typ=2 Len=1: 128
SQL>
2表⽰number类型
len表⽰1字节
128表⽰字节bit为 1000 0000 ---> Ox 80 SQL> select dump(1111111) from dual; DUMP(1111111)
---------------------------
Typ=2 Len=5: 196,2,12,12,12
SQL> select dump(1111111111111) from dual; DUMP(1111111111111)
------------------------------------
Typ=2 Len=8: 199,2,12,12,12,12,12,12
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论