Oracle建表经常使用数据类型详解(原创)

建立表时,必须为表的各个列指定数据类型。若是实际的数据与该列的数据类型不相匹配,则数据库会拒绝保存。如为学生指定出生日期为“1980-13-31”。 数据库

在Oracle中,常见的数据类型有:
字符串:字符串分为定长类型char和变长类型varchar2。
数字:整数 number(整数位),小数 number(总长度,小数位),只写number,表示无限制。
日期:date类型,能够保存年月日时分秒。
编程

问题:Oracle中为何字符串类型为varchar2,它与varchar有什么关系?
回答:
在Oracle中, varchar已经做为了保留字。若是你使用varchar类型,Oracle也不会报错,可是建表之后你会发现,已经自动变为了varchar2类型。
操作系统

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

问题:如何为字符串和数字类型指定长度?
char类型能够不指定长度,则默认为1,而varchar2必须指定长度。
char和varchar类型的长度最大长度大约在4000多一点点。
number表示不限整数或小数,它可以保存很是大的数字或者保存小数位很是多的数字。因此为了节约磁盘空间,尽可能指定长度。
date:不须要指定长度。
图片

问题:字符串最大长度约为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——定长类型。
如将姓名列指定为char(8)。当保存“张三”时,数据库还会自动保存4个空格;保存“张三丰”时,数据库还会自动保存2个空格,这样每一个人的姓名长度都为8,长度是固定的,因此叫作“定长”。明显,在保存信息时,定长会由于保存了很空格而多占用了磁盘空间。
数据库保存这些“多余”的空格有什么做用?
那就是查询时,在取到字段的长度之后,再也不须要判断每个姓名的实际长度,就能够取到数据。这样查询效率大大提升了。
字符串

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

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

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

相关文章
相关标签/搜索