oracle数据库类型

发布日期:2014-03-19 17:06:42

前言:
为列指定数据类型并不难,难的是指定合适的数据类型。同样是字符串类型,选择定长还是变长,其中大有文章。所以需要耐心而细致的学习下面的内容。


创建表时,必须为表的各个列指定数据类型。如果实际的数据与该列的数据类型不相匹配,则数据库会拒绝保存。如为学生指定出生日期为“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类型要低。

 

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

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

oracle10g数据类型介绍见下表:

数据类型

取值范围

描述

备注

Char(n)

n=1 to 2000字节

存储固定长度的字符串。默认长度为1

 

Varchar2(n)

n=1 to 4000字节

可变长的字符串,具体定义时指明最大长度n
这种数据类型可以放数字、字母以及ASCII码字符集(或者EBCDIC等数据库系统接受的字符集标准)中的所有符号。
如果数据长度没有达到最大值nOracle 会根据数据大小自动调节字段长度,
如果你的数据前后有空格,Oracle 8会自动将其删去。VARCHAR2是最常用的数据类型。
可做索引的最大长度3209Varchar2类型的字段长度可以达到4000字节,Varchar2类型的变量长度可以达到32676字节。

节省表空间:一个空的varchar2(2000)字段和一个空的varchar2(2)字段所占用的空间是一样的。

Nchar(n)

n=1 to 2000字节

Unicode数据类型,只能存储utf-16utf-8的数据。存储固定长度的字符串。

 

Nvarchar2(n)

n=1 to 4000字节

Unicode数据类型,只能存储utf-16utf-8的数据。存储变长字符串。

 

Long

最大2G

可变长字符列,最大长度限制是2GB,用于不需要作字符串搜索的长串数据,如果要进行字符搜索就要用varchar2类型。
long
是一种较老的数据类型,将来会逐渐被BLOBCLOBNCLOB等大的对象数据类型所取代。

在不同系统间移动需要进行转换。

Clob

最大4G

存储单字节字符型数据。适用于存储超长文本。

 

Nclob

最大4G

存储多字节国家字符型数据。适用于存储超长文本。

 

Blob

最大4G

存储二进制数据。适用于存储图像、视频、音频等。

 

Bfile

最大长度是4GB

在数据库外部保存的大型二进制对象文件,最大长度是4GB。这种外部的LOB类型,通过数据库记录变化情况,但是数据的具体保存是在数据库外部进行的。

Oracle 可以读取、查询BFILE,但是不能写入,不参与事务。

 

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

 

数据类型用来存储日期和时间格式的数据。默认格式:DD-MON-YYYY。从公元前471211日到公元47121231日的所有合法日期

 

Row(n)

n=1 to 2000

可变长二进制数据,在具体定义字段的时候必须指明最大长度nOracle 用这种格式来保存较小的图形文件或带格式的文本文件,如Miceosoft Word文档。
raw
是一种较老的数据类型,将来会逐渐被BLOBCLOBNCLOB等大的对象数据类型所取代。

 

LongRow

最大长度是2GB

可变长二进制数据,最大长度是2GBOracle 用这种格式来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件。
在同一张表中不能同时有long类型和long raw类型,long raw也是一种较老的数据类型,将来会逐渐被BLOBCLOBNCLOB等大的对象数据类型所取代。

 

Rowid

 

数据类型是ORACLE数据表中的一个伪列,它是数据表中每行数据内在的唯一的标识。

 



1、字符型:

  char(n):用于标识固定长度的字符串。

  当实际数据不足定义长度时,使用空格补全右边不足位。

  varchar(n):可变字符串类型。

  为SQL标准规定的,数据库必须实现的数据据类型。

  可以存储空字符串。

  varchar2(n):可变字符串类型。

  是oracle在varchar的基础上自行定义的可变长度

  字符串类型。当做为列类型使用时,最大长度可被定义为4000;当做为变量类型使用时,长度可被定义为32767。

  不可以存储空字符串。

  2、数值型:可用于存储整数、浮点数。

  number(m,n):m表示有效数字的总位数(最大为38位),n表示小 数位数。

  3、日期时间型:

  date:包含Year(年)、Month(月) 、Day(天)、Hour(时)、Minutes(分)、Second(秒)

  说明:(yyyy表示4位年分;mm表示月份;dd表示天;hh表示时;mi表示分;ss表示秒)

  4、大对象类型:

  lob:用于存储大对象类型。例如:文本信息长度超过4000、二进制文件等。最大容量为4GB。

  lob分类:clob:用于存储大型文本数据。(例如:备注信息)

  blob:用于存储二进制数据。(例如:图片文件)

  bfile:作为独立文件存在的二进制数据。

  5、特殊数据:

  null与空字符串:null与空字符串,都要用is null或is not null进行比较。

  单引号:想将单引号做为字符中使用,请通过单引号进行转义。

  例如:'''张三',则数据库会保存为'张三。

  6、注意:oracle中,没有布尔类型,可利用字符串或数值(1/0)表示