oracle中的常用数据类型

来源:互联网 发布:java如何实现增删改查 编辑:程序博客网 时间:2024/05/22 12:32

ORACLE常用数据类型

  1. CHAR(N)或CHAR(N BYTE):固定长度字符串(以字节长度为单位) 最大长度2000 bytes
  2. CHAR(N CHAR):固定长度字符串(以字符个数为单位)
  3. VARCHAR2(N)或VARCHAR2(N BYTE):可变长度的字符串(以字节长度为单位) 最大长度4000 bytes 可做索引的最大长度749
  4. VARCHAR2(N CHAR):可变长度的字符串以字符个数为单位)
  5. NUMBER(P,S): 数字类型 P为整数位,S为小数位 DECIMAL(P,S) 数字类型 P为整数位,S为小数位
  6. DATE :日期(日-月-年) DD-MM-YY(HH-MI-SS)
  7. TIMESTAMP:是DATA数据类型的扩展
  8. RAW: 固定长度的二进制数据 最大长度2000 bytes 可存放多媒体图象声音等
  9. NCHAR 根据字符集而定的固定长度字符串 最大长度2000 bytes
  10. NVARCHAR2 根据字符集而定的可变长度字符串 最大长度4000 bytes (涉及多语言问题时使用NVARCHAR2,一般都使用VARCHAR2 )
  11. LONG 超长字符串 最大长度2G(231-1) 足够存储大部头著作
  12. LONG RAW 可变长度的二进制数据 最大长度2G 同上
  13. BLOB 二进制数据 最大长度4G
  14. CLOB 字符数据 最大长度4G
  15. NCLOB 根据字符集而定的字符数据 最大长度4G
  16. BFILE 存放在数据库外的二进制数据 最大长度4G
  17. ROWID 数据表中记录的唯一行号 10 bytes ********.****.****格式,*为0或1
  18. rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,而且rownum不能以任何表的名称作为前缀。
  19. NROWID 二进制数据表中记录的唯一行号 最大长度4000 bytes
  20. INTEGER 整数类型 小的整数
  21. FLOAT 浮点数类型 NUMBER(38),双精度
  22. REAL 实数类型 NUMBER(63),精度更高

问题:Oracle中为什么字符串类型为varchar2,它与varchar有什么关系?
在Oracle中, varchar已经作为了保留字。如果你使用varchar类型,Oracle也不会报错,但是建表以后你会发现,已经自动变为了varchar2类型。

问题:用number还是用integer(整数)?
另外Oracle也有integer等其它类型,但是用integer有缺点,就是不知道其长度,甚至可能在不同的操作系统上(如32位CPU和64位CPU)所分配的长度是不同的。而用number,指定多少,就永远是多少,一切掌握在自己手中

重点问题:定长类型和变长类型和什么区别?
两者主要的区别体现在存储上和查询效率上。
首先讲char——定长类型。
如将姓名列指定为char(8)。当保存“张三”时,数据库还会自动保存4个空格;保存“张三丰”时,数据库还会自动保存2个空格,这样每个人的姓名长度都为8,长度是固定的,所以叫做“定长”。明显,在保存信息时,定长会因为保存了很空格而多占用了磁盘空间。
数据库保存这些“多余”的空格有什么作用?
那就是查询时,在取到字段的长度以后,不再需要判断每一个姓名的实际长度,就可以取到数据。这样查询效率大大提高了。

下面再讲varchar2——变长类型。
如将姓名列指定为varchar2(8)。当保存“张三”和保存“张三丰”时,数据库都只保存数据的本身,不会自动添加空格。两个人姓名的长度分别为4和6,长度是变化的,所以叫做“变长”。这样没有多占用任何磁盘空间。
但是在查询时,每个人的姓名的长度都不同,必须先判断后取数据,所以查询效率比char类型要低。

问题:字符串最大长度约为4000。如果要保存更多的内容怎么办?
解决的方法有两种。第一种是用大对象类型,即CLOB或者BLOB类型,但是编程比较麻烦;第二种是用一对多的父子表实现。
大对象是指大量的数据。如果用char或varchar2,列的最大长度大约在4000多;如果内容更多,其中一个方法就是将列设置为CLOB类型,但是只限制保存字符数据,如小说。如果是二进制数据,如图片、声音、office文档,则需要将列设置BLOB类型。CLOB或BLOB最大能够装4G的内容。如果是电影,则更通常的做法是在表中保存电影的名称、路径等信息,电影直接保存在磁盘上,而不是直接存储在数据库中,也不是用BFile类型。
示例:创建小说表
create table xiao_shuo(
xs_id number(10) primary key, --小说编号
xs_name varchar2(5), --小说名称
xs_contenct clob, --小说内容
xs_fen_mian blob --小说封面(图片)
);
第二种是利用父子表实现,例如:小说表(小说ID,小说标题),内容表(小说ID,行数,行内容),其中行内容为varchar(4000)。这表示每一行最多保存4000个字符。

小结:

char和varchar的关系就是空间和时间的关系,char是以空间换时间,牺牲了磁盘空间,但羸得了查询时间。

对于Oracle,还有更深层次的区别。
比如对于员工的“备注”信息,如果用varchar(4000)。有的员工备注原来很少,后来有可能加入大量的备注。由于varchar类型是没有在记录之间保存多余的空闲空间的,所以就会引用记录的“行迁移”,造成磁盘碎片,从而降低查询效率。而char类型则用空格已经占用了,不会引用磁盘空间的再分配。不会在项目使用过程中引用碎片问题。比如QQ签名、群简介等信息用户经常修改,用char就比varchar要好。

0 0
原创粉丝点击