四、Oracle初级学习之数据类型

1、CHAR:这是一个定长字符串,会用空格填充来达到其最大长度。非null 的CHAR(12.)总是包
含12.字节信息(使用了默认国家语言支持National Language Support,NLS 设置)。稍后将
更详细地介绍NLS 的作用。CHAR字段最多可以存储2,000字节的信息。


2、NCHAR:这是一个包含UNICODE格式数据的定长字符串。Unicode是一种对字符进行编码
的通用方法,而不论使用的是何种计算机系统平台。有了NCHAR 类型,就允许数据库中包含
采用两种不同字符集的数据:使用数据库字符集的CHAR 类型和使用国家字符集的NCHAR类
型。非null 的NCHAR(12.)总是包含12.个字符的信息(注意,在这方面,它与CHAR 类型有
所不同)。NCHAR字段最多可以存储2,000字节的信息。


3、VARCHAR2:目前这也是VARCHAR 的同义词。这是一个变长字符串,与CHAR 类型不同,
它不会用空格填充至最大长度。VARCHAR2(12.)可能包含0~12.字节的信息(使用默认NLS
设置)。VARCHAR2最多可以存储4,000 字节的信息。


4、NVARCHAR2:这是一个包含UNICODE 格式数据的变长字符串。NVARCHAR2(12.)可以包
含0~12.字符的信息。NVARCHAR2最多可以存储4,000 字节的信息。


5、RAW:这是一种变长二进制数据类型,这说明采用这种数据类型存储的数据不会发生字符集转
换。可以把它看作由数据库存储的信息的二进制字节串。这种类型最多可以存储2,000 字节的
信息。


6、NUMBER:这种数据类型能存储精度最多达38位的数字。这些数介于12.0×12.(-130)——(但
不包括)12.0×12.(126)之间。每个数存储在一个变长字段中,其长度在0(尾部的NULL列就是
0 字节)~22字节之间。Oracle的NUMBER类型精度很高,远远高于许多编程语言中常规的
FLOAT和DOUBLE类型。


7、BINARY_FLOAT:这是Oracle 10g Release 1及以后版本中才有的一种新类型。它是一个32
位单精度浮点数,可以支持至少6 位精度,占用磁盘上5字节的存储空间。


8、LONG:这种类型能存储最多2G的字符数据(2GB是指2千兆字节,而不是2 千兆字符,因
为在一个多字节字符集中,每个字符可能有多个字节)。由于LONG 类型有许多限制(后面会讨
论),而且提供LONG 类型只是为了保证向后兼容性,所以强烈建议新应用中不要使用LONG
类型,而且在现有的应用中也要尽可能将LONG类型转换为CLOB类型。


9、LONG RAW:LONG RAW类型能存储多达2GB的二进制信息。由于LONG同样的原因,建
议在将来的所有开发中都使用CLOB 类型,另外现有的应用中也应尽可能将LONG RAW 转换
为BLOB类型。


10、DATE:这是一个7字节的定宽日期/时间数据类型。其中总包含7个属性,包括:世纪、世纪
中哪一年、月份、月中的哪一天、小时、分钟和秒。


11、TIMESTAMP:这是一个7 字节或12.字节的定宽日期/时间数据类型。它与DATE 数据类型不
同,因为TIMESTAMP 可以包含小数秒(fractional second);带小数秒的TIMESTAMP 在小
数点右边最多可以保留9 位。


12、TIMESTAMP WITH TIME ZONE:与前一种类型类似,这是一个12.字节的定宽TIMESTAMP,
不过它还提供了时区(TIME ZONE)支持。数据中会随TIMESTAMP存储有关时区的额外信息,
所以原先插入的TIME ZONE会与数据一同保留。


13、TIMESTAMP WITH LOCAL TIME ZONE:与TIMESTAMP类似,这是一种7字节或12.字节
的定宽日期/时间数据类型;不过,这种类型对时区敏感(time zone sensitive)。如果在数据
库中有修改,会参考数据中提供的TIME ZONE,根据数据库时区对数据中的日期/时间部分进
行“规范化”。所以,如果你想使用U.S./Pacific 时区插入一个日期/时间,而数据库时区为
U.S./Eastern,最后的日期/时间信息会转换为Eastern 时区的日期/时间,并像TIMESTAMP一
样存储。获取这个数据时,数据库中存储的TIMESTAMP将转换为会话时区的时间。

14、INTERVAL YEAR TO MONTH:这是一个5字节的定宽数据类型,用于存储一个时间段,这
个类型将时段存储为年数和月数。可以在日期运算中使用这种时间间隔使一个DATE 或
TIMESTAMP类型增加或减少一段时间。


15、INTERVAL DAY TO SECOND:这是一个12.字节的定宽数据类型,用于存储一个时段,这个
类型将时段存储为天/小时/分钟/秒数,还可以有最多9位的小数秒。


16、BFILE:这种数据类型允许在数据库列中存储一个Oracle目录对象(操作系统目录的一个指针)
和一个文件名,并读取这个文件。这实际上允许你以一种只读的方式访问数据库服务器上可用
的操作系统文件,就好像它们存储在数据库表本身中一样。


17、BLOB:在Oracle9i 及以前的版本中,这种数据类型允许存储最多4GB的数据,在Oracle 10g
及以后的版本中允许存储最多(4GB)×(数据库块大小)字节的数据。BLOB包含不需要进行
字符集转换的“二进制“数据,如果要存储电子表格、字处理文档、图像文件等就很适合采用
这种数据类型。


18、CLOB:在Oracle9i 及以前的版本中,这种数据类型允许存储最多4GB的数据,在Oracle 10g
及以后的版本中允许存储最多(4GB)×(数据库块大小)字节的数据。CLOB包含要进行字符
集转换的信息。这种数据类型很适合存储纯文本信息。


19、NCLOB:在Oracle9i及以前的版本中,这种数据类型允许存储最多4GB的数据,在Oracle 10g
及以后的版本中允许存储最多(4GB)×(数据库块大小)字节的数据。NCLOB 存储用数据库
国家字符集编码的信息,而且像CLOB一样,这些信息要进行字符集转换。


20、ROWID:ROWID 实际上是数据库中一行的12.字节地址。ROWID 中编码有足够的信息,足
以在磁盘上定位这一行,以及标识ROWID指向的对象(表等)。

21、UROWID:UROWID 是一个通用ROWID,用于表(如IOT 和通过异构数据库网关访问的没
有固定ROWID的表)。UROWID是行主键值的一种表示,因此,取决于所指向的对象,UROWID
的大小会有所变化。

 

INT、INTEGER、SMALLINT、FLOAT、REAL等。这些类型实际上都是在上表所列的某种类型的基础上实现的,也就是说,它们只是固有Oracle类型的同义词。另外,诸如XML Type、SYS.ANYTYPE和SDO_GEOMETRY之类的类型,它们是一些复杂的对象类型,包括一个属性集合以及处理这些属性的一些方法(函数)。这些复杂类型由上述基本数据类型组成,并不是传统意义上真正的数据类型

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值