数据类型 含义
char 定长的字符型数据,最大长度可达2KB
nchar 存储Unicode字符集的定长字符型数据,最大长度为2KB
Varchar2 可变长的字符型数据,最大长度可达4000个字符
Nvarchar2 存储Unicode字符集的变长字符型数据,最大长度为4KB
number 存储整型或浮点型数据
Date 存储日期数据
Long 存储最大长度为2GB的变长字符数据
Raw 存储非结构化数据的变长字符数据,最长为2KB
Long Raw 存储非结构化数据的变长字符数据,最长为2GB
Rowid 存储表中列的物理地址的二进制数据,占用固定的10个字节
Blog 二进制大对象,最大长度为4GB
Clob 字符大对象,最大长度为4GB
Nclob 存储多达4GB的Unicode字符数据
Bfile 把非结构化的二进制数据存储在数据库以外的操作系统文件中
Urowid 存储表示任何类型列地址的二进制数据
float 存储浮点数
一、概述
标量(SCALAR)、复合(COMPOSITE)、引用(REFERENCE)和LOB四种数据类型,下面详细介绍它们的特性。
二、标量(SCALAR)
合法的标量类型与数据库的列所使用的类型相同,此外它还有一些扩展。它又分为七个组:数字、字符、行、日期、行标识、布尔和可信。
数字,它有三种基本类型--NUMBER、PLS_INTEGER和BINARY_INTENER。NUMBER可以描述整数或实数,而PLS_INTEGER和BINARY_INTENER只能描述整数。
NUMBER,是以十进制格式进行存储的,它便于存储,但是在计算上,系统会自动的将它转换成为二进制进行运算的。它的定义方式是NUMBER(P,S),P是精度,最大38位,S是刻度范围,可在-84...127间取值。例如:NUMBER(5,2)可以用来存储表示-999.99...999.99间的数值。P、S可以在定义是省略,例如:NUMBER(5)、NUMBER等;
BINARY_INTENER用来描述不存储在数据库中,但是需要用来计算的带符号的整数值。它以2的补码二进制形式表述。循环计数器经常使用这种类型。
PLS_INTEGER和BINARY_INTENER唯一区别是在计算当中发生溢出时,BINARY_INTENER型的变量会被自动指派给一个NUMBER型而不会出错,PLS_INTEGER型的变量将会发生错误。
字符,包括CHAR、VARCHAR2(VARCHAR)、LONG、NCHAR和NVARCHAR2几种类型。
CHAR,描述定长的字符串,如果实际值不够定义的长度,系统将以空格填充。它的声明方式如下CHAR(L),L为字符串长度,缺省为1,作为变量最大32767个字符,作为数据存储在ORACLE8中最大为2000。
VARCHAR2(VARCHAR),描述变长字符串。它的声明方式如下VARCHAR2(L),L为字符串长度,没有缺省值,作为变量最大32767个字节,作为数据存储在ORACLE8中最大为4000。在多字节语言环境中,实际存储的字符个数可能小于L值,例如:当语言环境为中文(SIMPLIFIED CHINESE_CHINA.ZHS16GBK)时,一个VARCHAR2(200)的数据列可以保存200个英文字符或者100个汉字字符。
LONG,在数据库存储中可以用来保存高达2G的数据,作为变量,可以表示一个最大长度为32760字节的可变字符串。
NCHAR、NVARCHAR2,国家字符集,与环境变量NLS指定的语言集密切相关,使用方法和CHAR、VARCHAR2相同。
行,包括RAW和LONG RAW两种类型。用来存储二进制数据,不会在字符集间转换。
RAW,类似于CHAR,声明方式RAW(L),L为长度,以字节为单位,作为数据库列最大2000,作为变量最大32767字节。
LONG RAW,类似于LONG,作为数据库列最大存储2G字节的数据,作为变量最大32760字节。
日期,只有一种类型--DATE,用来存储时间信息,
站用7个字节(从世纪到秒),绝对没有“千年虫”问题。
行标识,只有一种类型--ROWID,用来存储“行标识符”,可以利用ROWIDTOCHAR函数来将行标识转换成为字符。
布尔,只有一种类型--BOOLEAN,仅仅可以表示TRUE、FALSE或者NULL。
可信,只有一种类型--MLSLABEL,可以在TRUSTED ORACLE中用来保存可变长度的二进制标签。在标准ORACLE中,只能存储NULL值。
三、复合(COMPOSITE)
标量类型是经过预定义的,利用这些类型可以衍生出一些复合类型。主要有记录、表。
记录,可以看作是一组标量的组合结构,它的声明方式如下:
TYPE record_type_name IS RECORD
( filed1 type1 [NOT NULL] [:=eXPr1]
.......
filedn typen [NOT NULL] [:=exprn] )
其中,record_type_name是记录类型的名字。(是不是看着象CREATE TABLE?......)引用时必须定义相关的变量,记录只是TYPE,不是VARIABLE。
表,不是物理存储数据的表,在这里是一种变量类型,也称为PL/SQL表,它类似于C语言中的数组,在处理方式上也相似。它的声明方式如下:
TYPE table_type_name IS TABLE OF scalar_type INDEX BY BINARY_INTENER;
其中,table_type_name是类型的名字,scalar_type是一种标量类型的类型声明。引用时也必须定义相关的变量。表和数组不同,表有两列,KEY和VALUE,KEY就是定义时声明的BINARY_INTENER,VALUE就是定义时声明的scalar_type。
除了记录和表之外,还有对象类型、集合(嵌套表和VARRAYS)等类型,这些将专门讲解。
四、引用(REFERENCE)
在PL/SQL8.0之前,只有一种类型--REF CURSOR,也就是游标。它的定义较为简单,
CURSOR cursor_name IS select .....from.....;
在PL/SQL8.0之后,引入了REF类型,它指向一个对象。这种类型将单独讲解。(等我弄明白再说,免得在高人面前......)
五、LOB型
LOB变量主要是用来存储大量数据的数据库字段,最大可以存储4G字节的内容(这么大,存VCD?,浪费!)。主要有:
CLOB:和ORACLE7中的LONG类型相似,存储单字节字符数据。(别用来存中文喔。。。)
NCLOB:用来存储定宽多字节字符数据。(例如:存《啸傲江湖》就挺好)
BLOB:和LONG RAW相似,用来存储无结构的二进制数据。
BFILE:它用来允许ORACLE对数据库外存储的大型二进制文本进行只读形式的访问
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/java_cxrs/archive/2009/02/15/3893440.aspx
分享到:
相关推荐
oracle数据类型总结PPT,类型之间的区别
oracle数据类型的经典学习资料
oracle新手入门指导之四——ORACLE数据类型 .txtoracle新手入门指导之四——ORACLE数据类型 .txt
Oracle的数据类型: 1、CHAR数据类型,该类型是固定长度的字符串,如果没指定大小,则默认占用一字节,如果输入的值小于指定的长度,则数据库用空格填充至固定长度,如果用户输入的值大于指定的长度,则数据库...
Oracle数据类型之Number, 全方位介绍Number数据类型。
oracle数据库中各种数据类型的详细说明
oracle数据类型.docoracle数据类型.doc
ORACLE数据类型
RT oracle数据类型及存储方式.doc
公司内部培训V3.0 oracle 数据类型及常用函数培训
关于oracle数据类型及存储方式基础知识,也许对你有所帮助
oracle数据类型,CHAR 固定长度字符串 最大长度2000 bytes
Oracle10g reference操作手册,附Oracle数据类型精解,以及Powerdesigner实例傻瓜式图文教程,方便入门的同时提供相应实际实践经验
Oracle数据类型说明,CHAR VARCHAR2 NCHAR NVARCHAR2 等
涵盖很全的Oracle 10g数据库学习教程,我在网上找了很久才找到,适合初学oracle的人学习。
Oracle实用教程_04章_Oracle数据类型和函数[整理].pdf
SqlServer,Oracle数据类型,函数,导入导出对照
Oracle 数据类型及存储方式 数据存储是数据流在加工过程中产生的临时文件或加工过程中需要查找的信息。数据以某种格式记录在计算机内部或外部存储介质上。
不同于MySQL,Oracle有着其独特的数据类型,本文档整理了Oracle常用的数据类型,并对不同数据类型的使用场景进行了描述。