ORACLE数据类型说明
Oracle中的数据类型
Oracle中的数据类型Ø简介本⽂主要来讨论 Oracle 中的数据类型,包括以下内容:1.概念介绍2.数值类型3.字符类型4.⽇期类型5.⼤数据与⼆进制类型6.列举常⽤类型的数字代码1.概念介绍在我们的程序中有各种数据类型,⽽在 Oracle 中也有很多种类型,其实每⼀种语⾔的数据类型都会跟数据库中的数据类型⼤致的对应起来。
⽐如:在 Oracle 中主要分为四⼤数据类型,即:数字类型、字符类型、⽇期类型,以及⼤数据与⼆进制类型,下⾯就来讨论着⼏种常⽤的数据类型。
2.数值类型1)NUMBER(Type = 2)number 类型是 Oracle 中常⽤的数据类型,即可以⽤于存储整数整数,也可以存储⼩数⼩数,是⼀个⾮常有意思的数据类型。
number 是⼀个可变长度可变长度的数据类型,并且始终保持四舍五⼊四舍五⼊的原则。
number 可以指定两个参数 number(p,s):l p表⽰有效位,从左边第⼀个⾮0的数字开始数,到结尾的长度,取值范围:1 ~ 38;l s表⽰⼩数位,取值范围:-84 ~ 127。
注意:注意:通常情况下(需要整数位时),应该 p > s,例如:1.number(3,2) 只能存储:0.01 ~ 9.99 和 -0.01 ~ -9.992.number(3,3) 只能存储:0.001 ~ 0.999 和 -0.001 ~ -0.9993.number(2,3) 只能存储:0.001 ~ 0.099 和 -0.001 ~ -0.099n number 可以表⽰的数值范围:-1.0e-130 ~ 1.0e+126,占⽤空间为1 ~ 22 个字节。
下⾯看⼏个常见的例⼦:1.numbercreate table t_number(num number);insert into t_number values(56);insert into t_number values(56.78);select * from t_number;执⾏以上语句,实际存储为56和56.78。
oracle数据库基本数据类型
oracle数据库基本数据类型
Oracle数据库有许多基本数据类型,包括:
1. 字符型:
- CHAR:固定长度的字符型,最长可达2000个字节。
- VARCHAR2:可变长度的字符型,最长可达4000字节。
- CLOB:用于存储大量文本数据的字符型,最长可达4GB。
- NCHAR:固定长度的Unicode字符型,最长可达2000个字节。
- NVARCHAR2:可变长度的Unicode字符型,最长可达4000字节。
- NCLOB:用于存储大量Unicode文本数据的字符型,最长可达4GB。
2. 数值型:
- NUMBER:用于存储数值数据的类型,包括整数和浮点数。
- BINARY_FLOAT:用于存储单精度浮点数。
- BINARY_DOUBLE:用于存储双精度浮点数。
3. 日期和时间型:
- DATE:用于存储日期和时间信息。
- TIMESTAMP:用于存储日期、时间和时区信息。
4. 二进制型:
- RAW:用于存储二进制数据的类型,最长可达2000字节。
- BLOB:用于存储大量二进制数据的类型,最长可达4GB。
5. BOOLEAN型:用于存储布尔值(TRUE或FALSE)。
这些基本数据类型可以通过组合和修饰符进行扩展和定制。
oracle的大文本类型
oracle的大文本类型
Oracle数据库中支持大文本类型,即CLOB和NCLOB类型。
CLOB 类型用于存储长文本数据,最大长度为4GB,NCLOB则用于存储Unicode字符集的长文本数据,最大长度也为4GB。
CLOB类型的数据可以通过INSERT、UPDATE和SELECT语句进行操作。
需要注意的是,由于CLOB类型的数据比较大,所以需要使用LOB locator来访问和修改CLOB数据。
NCLOB类型与CLOB类型类似,只是它可以存储Unicode字符集的数据。
同样,NCLOB类型的数据也需要使用LOB locator来访问和修改。
在使用CLOB和NCLOB类型时,需要注意以下几点:
1. 在创建表时,需要指定该列的数据类型为CLOB或NCLOB。
2. 在插入数据时,需要使用“TO_LOB”函数将数据转换为LOB locator。
3. 在查询数据时,需要使用“DBMS_LOB.SUBSTR”函数来获取CLOB或NCLOB数据的子串。
4. 在更新数据时,需要使用“DBMS_LOB.WRITE”函数来修改CLOB 或NCLOB数据。
总之,大文本类型在Oracle数据库中是非常有用的数据类型,可以方便地存储和操作长文本数据。
但是,由于数据量较大,需要注意一些细节问题。
- 1 -。
oracle的varchar类型
oracle的varchar类型
摘要:
1.Oracle 的VARCHAR 类型的定义和特点
2.VARCHAR 类型的使用限制和注意事项
3.VARCHAR 类型的存储方式和性能影响
4.VARCHAR 类型的优缺点
正文:
Oracle 的VARCHAR 类型是Oracle 数据库中用于存储字符串数据的一种数据类型。
它允许用户在数据库中存储长度不一的字符串数据,并且支持对字符串数据进行各种操作,如字符串连接、子串提取等。
在使用VARCHAR 类型时,需要注意一些限制和注意事项。
首先,VARCHAR 类型的最大长度为4000 字节,超过这个长度需要使用其他数据类型,如CLOB 或BLOB。
其次,VARCHAR 类型的长度必须是2 的整数次幂,不能是任意整数。
此外,VARCHAR 类型的字符集必须与数据库的字符集匹配,否则可能会导致数据存储或查询错误。
VARCHAR 类型的存储方式是基于字符的,即每个字符占用一个字节。
如果字符串中包含中文字符,则需要使用更多的字节来存储。
因此,VARCHAR 类型的存储效率相对于其他字符串数据类型(如CLOB 或BLOB)较低。
但是,VARCHAR 类型的查询和索引效率较高,因为它可以直接在数据库中进行字符串操作。
总的来说,VARCHAR 类型是一种灵活且高效的字符串数据类型,适用于
存储长度较短的字符串数据。
但是,如果需要存储较长的字符串数据,可以考虑使用CLOB 或BLOB 类型,以提高存储效率。
oracle 的数据类型
Oracle的数据类型一、概述在Oracle数据库中,数据类型是定义列或变量的属性,用于存储不同类型的数据。
数据类型在数据库设计和数据存储过程中起着关键的作用。
Oracle提供了丰富的数据类型,包括数值类型、字符类型、日期类型、大对象类型等。
本文将详细介绍Oracle的各种数据类型及其特点。
二、数值类型1. NUMBERNUMBER是Oracle中最常用的数值类型。
它可以存储任意精度的数值,包括整数和小数。
以下是一些常见的NUMBER类型的子类型:•NUMBER(precision): 存储精度为precision的数值。
•NUMBER(precision, scale): 存储精度为precision且小数位数为scale的数值。
2. INTEGERINTEGER是一种整数类型,它只能存储整数值。
它可以使用以下子类型:•INTEGER(precision): 存储精度为precision的整数值。
3. BINARY_FLOAT和BINARY_DOUBLEBINARY_FLOAT和BINARY_DOUBLE是用于存储浮点数的数据类型。
BINARY_FLOAT用于单精度浮点数,BINARY_DOUBLE用于双精度浮点数。
1. CHARCHAR是一种定长字符类型,它可以存储固定长度的字符串。
在创建CHAR类型的列或变量时,必须指定长度。
2. VARCHAR2VARCHAR2是一种可变长度字符类型,它可以存储可变长度的字符串。
在创建VARCHAR2类型的列或变量时,必须指定最大长度。
3. CLOBCLOB是用于存储大文本对象的数据类型。
它可以存储最大长度为4GB的文本数据。
四、日期类型1. DATEDATE是Oracle中用于存储日期和时间的数据类型。
它存储的范围从公元前4712年到公元9999年。
2. TIMESTAMPTIMESTAMP用于存储日期和时间,精确到纳秒级别。
它包括以下子类型:•TIMESTAMP: 存储日期和时间,精确到秒级别。
Oracle数据类型
oracle数据类型以下的大多数类型的描述都经本人验证,但不免有错误,请不吝赐教(oracle: 10.2.0.3.0 ,plsql: 7.1.5.1398 )注:以下两个函数有助于理解数据类型length() 当前列存储值的字符长度;vsize() 当前列存储值所占用字节数。
1.CHAR固定长度字符域, 最大长度可达2000 个字符或者字节。
默认指定为以字符形式进行存储,并且当位数不够时oracle 在其右边添加空格来补满。
例如:2.VARCHAR2可变长度字符域,最大长度可达4000 个字符。
例如:CREATE TABLE test(name varchar2(20))2.1.CHAR和VARCHAR2区别1.CHAR 的长度是固定的,而VARCHAR2 的长度是可以变化的,比如,存储字符串,对于CHAR (20),表示你存储的字符将占20 个字节(包括17 个空字符),而同样的VARCHAR2 (20)则只占用3 个字节的长度,20 只是最大值,当你存储的字符小于20 时,按实际长度存储。
2 .CHAR 的效率比VARCHAR2 的效率稍高。
3.目前VARCHAR 是VARCHAR2 的同义词。
工业标准的VARCHAR 类型可以存储空字符串,但是Oracle 不这样做,尽管它保留以后这样做的权利。
Oracle 自己开辟了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库中varchar 列可以存储空字符串的特性改为存储NULL 值。
假如你想有向后兼容的能力,Oracle 建议使用VARCHAR2 而不是VARCHAR。
何时该用CHAR,何时该用varchar2?CHAR 与VARCHAR2 是一对矛盾的统一体,两者是互补的关系. VARCHAR2 比CHAR 节省空间,在效率上比CHAR 会稍微差一些,即要想获得效率,就必须牺牲一定的空间,这也就是我们在数据库设计上常说的‘以空间换效率’ 。
有关 Varchar 与 VarChar2 数据类型的说明
有关VarChar与VarChar2数据类型的说明
Oracle 提供了两种变长字符串数据类型,一为VarChar 一为VarChar2,它们的区别在于:VarChar 每个字符所占的字节数并不一致,全角字符占两个字节,半角字符占一个字节;VarChar2 则类似于Unicode 编码形式,不管是全角字符还是半角字符,都会占用两个字节。
在大多数情况下,推荐使用VarChar2 数据类型,因其兼容性比较好,而且不存在长度计算方面的问题。
但是在定义VarChar2的时候需要注意,我们通常的定义方式是采用类似于“aa VarChar2(20)”这种写法,按照我们的思路来说:这是一个字符型的字段,能容纳二十个字符。
但是实际测试一下,发现它只能容纳十个字符,这是因为VarChar2 数据类型的每个字符占用两个字节,而上面的定义语句定义的是字节数而非字符数!上面的语句正确的理解应该是:“一个字符型的字段aa ,其容量是20个字节”。
如果想要定义实际的字符数,可以这样写:“aa VarChar2(20 char)”,这种写法才是定义真正的20个字符。
使用SubStr 等字符串函数的时候也应注意这个问题,原因在于SubStr 之类的函数也是按“字符”来操作的,所以可能导致字段超限的情况发生,如果遇到类似前面的语句定义的那种形式,则SubStr 一类的函数的长度参数应该除以2才能确保不出问题。
建立数据库时应明确使用字符数而非字节数来定义VarChar2 数据类型,这将是个好习惯。
ORACLE数据库字段类型说明
ORACLE数据库字段类型说明类型含义存储描述备注CHAR固定长度字符串最⼤长度2000bytesVARCHAR2可变长度的字符串,最⼤长度4000bytes可做索引的最⼤长度749 NCHAR根据字符集⽽定的固定长度字符串最⼤长度2000bytesNVARCHAR2根据字符集⽽定的可变长度字符串最⼤长度4000bytesDATE⽇期(⽇-⽉-年)DD-MM-YY(HH-MI-SS),经过严格测试,⽆千⾍问题TIMESTAMP⽇期(⽇-⽉-年)DD-MM-YY(HH-MI-SS:FF3),经过严格测试,⽆千⾍问题与DATE相⽐较,TIMESTAMP有⼩数位秒信息LONG超长字符串最⼤长度2G,⾜够存储⼤部头著作RAW固定长度的⼆进制数据最⼤长度2000bytes可存放多媒体图象声⾳等LONG RAW可变长度的⼆进制数据最⼤长度2G可存放多媒体图象声⾳等BLOB⼆进制数据最⼤长度4GCLOB字符数据最⼤长度4GNCLOB根据字符集⽽定的字符数据最⼤长度4GBFILE存放在数据库外的⼆进制数据最⼤长度4GROWID数据表中记录的唯⼀⾏号10bytes**.*.*格式,*为0或1NROWID⼆进制数据表中记录的唯⼀⾏号最⼤长度4000bytesNUMBER(P,S)数字类型P为整数位,S为⼩数位DECIMAL(P,S)数字类型P为整数位,S为⼩数位INTEGER整数类型⼩的整数FLOAT浮点数类型NUMBER(38),双精度REAL实数类型NUMBER(63),精度更⾼**⽬前Oracle数据库⼤概有26个字段类型,⼤体分为六类,分别是字符串类型、数字数据类型、⽇期时间数据类型、=⼤型对象(LOB)数据类型、RAW和LONG RAW数据类型、ROWID和UROWID数据类型。
**当然Oracle还提供⽤户⾃定义的数据类型,但在我这篇不做讨论。
字符串类型Charchar数据类型存储固定长度的字符值。
⼀个CHAR数据类型可以包括1到2000个字符。
oracle number与entityframework 数据类型-概述说明以及解释
oracle number与entityframework 数据类型-概述说明以及解释1.引言1.1 概述概述:在现代的软件开发中,数据库和数据存储是至关重要的组成部分。
而在数据库设计中,数据类型也是一个非常重要的概念,不同的数据库系统对数据类型的定义和实现都有一定的差异。
在本文中,我们将重点讨论Oracle数据库中的Number数据类型以及在Entity Framework中对数据类型的映射和应用。
Oracle数据库是一种常用的关系型数据库管理系统,而Entity Framework是一种流行的对象关系映射框架,它可以帮助开发人员轻松地操作数据库。
通过对Oracle Number和Entity Framework数据类型的比较和分析,我们可以更好地理解它们之间的关系,了解在实际应用中如何选择和使用合适的数据类型,从而提高开发效率和数据存储的性能。
1.2文章结构1.2 文章结构本文将首先介绍Oracle Number数据类型的定义和特点,包括其在Oracle数据库中的应用和使用方法。
然后,将详细讨论Entity Framework 数据类型的概念和不同于Oracle Number的特性。
最后,将比较和分析Oracle Number和Entity Framework数据类型的异同,并探讨它们在实际应用中的应用场景和选用建议。
通过对这两种数据类型的深入研究和比较,读者将更好地了解它们各自的优缺点,以及在不同场景下的选择和应用的考虑因素。
1.3 目的:本文的主要目的是探讨和比较Oracle Number数据类型和Entity Framework数据类型之间的差异和应用。
通过深入分析这两种数据类型的特点、限制和优势,帮助读者更好地理解它们在不同环境下的使用场景和适用性。
同时,本文还旨在为开发人员提供关于如何在实际项目中正确选择和使用这两种数据类型的实用建议和技巧。
通过对比分析,读者可以更好地了解这两种数据类型的优劣势,从而在开发中做出明智的选择,提高开发效率和数据处理的准确性。
oracle 数据类型 oracle各数据类型之间的区别
RAW,类似于CHAR,声明方式RAW(L),L为长度,以字节为单位,作为数据库列最大2000,作为变量最大32767字节。
LONG RAW,类似于LONG,作为数据库列最大存储2G字节的数据,作为变量最大32760字节。
日期,只有一种类型--DATE,用来存储时间信息,站用7个字节(从世纪到秒),绝对没有“千年虫”问题。
除了记录和表之外,还有对象类型、集合(嵌套表和VARRAYS)等类型,这些将专门讲解。
四、引用(REFERENCE)
在PL/SQL8.0之前,只有一种类型--REF CURSOR,也就是游标。它的定义较为简单,
CURSOR cursor_name IS select .....from.....;
NCLOB:用来存储定宽多字节字符数据。(例如:存《啸傲江湖》就挺好)
BLOB:和LONG RAW相似,用来存储无结构的二进制数据。
BFILE:它用来允许ORACLE对数据库外存储的大型二进制文本进行只读形式的访问。
六、其他
其实在完成对标量变量的理解之后,基本上可以应付C/S模式下的常规数据库应用所需了,后续的类型说实话,我玩了5年ORACLE,都很少用到。
VARCHAR2(VARCHAR),描述变长字符串。它的声明方式如下VARCHAR2(L),L为字符串长度,没有缺省值,作为变量最大32767个字节,作为数据存储在ORACLE8中最大为4000。在多字节语言环境中,实际存储的字符个数可能小于L值,例如:当语言环境为中文(SIMPLIFIED CHINESE_CHINA.ZHS16GBK)时,一个VARCHAR2(200)的数据列可以保存200个英文字符或者100个汉字字符。
数字,它有三种基本类型--NUMBER、PLS_INTEGER和BINARY_INTENER。NUMBER可以描述整数或实数,而PLS_INTEGER和BINARY_INTENER只能描述整数。
Oracle11g数据类型
Oracle11g数据类型1. 字符类型数据类型长度说明CHAR(n BYTE/CHAR)默认1字节,n值最⼤为2000末尾填充空格以达到指定长度,超过最⼤长度报错。
默认指定长度为字节数,字符长度可以从1字节到四字节。
NCHAR(n)默认1字符,最⼤存储内容2000字节末尾填充空格以达到指定长度,n为Unicode字符数。
默认为1字节。
NVARCHAR2(n)最⼤长度必须指定,最⼤存储内容4000字节变长类型。
n为Unicode字符数VARCHAR2(n BYTE/CHAR)最⼤长度必须指定,⾄少为1字节或者1字符,n值最⼤为4000变长类型。
超过最⼤长度报错。
默认存储的是长度为0的字符串。
VARCHAR同VARCHAR2不建议使⽤2. 数字类型数据类型长度说明NUMBER(p[,s])1-22字节。
P取值范围1到38S取值范围-84到127存储定点数,值的绝对值范围为1.0 x 10 -130⾄1.0 x 10 126。
值⼤于等于1.0 x 10 126时报错。
p 为有意义的10进制位数,正值s为⼩数位数,负值s表⽰四舍五⼊到⼩数点左部多少位。
BINARY_FLOAT5字节,其中有⼀长度字节。
32位单精度浮点数类型。
符号位1位,指数位8位,尾数位23位。
BINARY_DOUBLE9字节,其中有⼀长度字节。
64位双精度浮点数类型。
3. 时间、时间间隔类型时间字段可取值范围:时间字段时间类型有效值时间间隔类型有效值YEAR-4712⾄9999,包括0任何整数MONTH01⾄120⾄11DAY01⾄31任何整数HOUR00 ⾄ 230 ⾄ 23MINUTE00 ⾄ 590⾄ 59SECOND00 to 59.9(n),9(n)不适⽤与DATE类型0 to 59.9(n)TIMEZONE_HOUR-1⾄14,不适⽤与DATE和TIMESTAMP类型不可⽤TIMEZONE_MINUTE00⾄59,不适⽤与DATE和TIMESTAMP类型不可⽤TIMEZONE_REGION不可⽤TIMEZONE_ABBR不可⽤时间、时间间隔类型:数据类型长度说明DATE7字节默认值为SYSDATE的年、⽉,⽇为01。
oracle(数据类型函数)
select lpad(ename,'10','*') from emp;
rpad //右侧填充 smith***** 10填充长度
select rpad(ename,'10','*') from emp;
trim //清除空格
round(314.1415,-2)结果 300
trunc()//截断
Select trunc(100.256,2) from dual; //结果 100.25
trunc(3.1415,3) 截断 3.141
ceil //向上取整
ceil(3.14)//结果 4 注意:ceilபைடு நூலகம்3.0)结果为3 返回不比3.14小的数据
//输出日期字段对应日后的第一个星期二
ROUND(x,y) //将日期x四舍五入到y指定日期单位(月或年)的第一天
select ename,hiredate,round(hiredate,'month') from emp;
//输出hiredate指定的月四舍五入的数据(如3月16就往前加一月等于4月1日,如3月15就不变还是3月1日)
//格式化输出数字(9代表一位数字,没有就不显示,但对于小数点后的强制显示)
2)select to_char(sal, '$00,000.0000') from emp;
//0代表一位数字,没有显示为0
3)select to_char(sal, 'L99,999.9999') from emp; //L代表本地货币
Oracle自定义数据类型1
Oracle⾃定义数据类型1⼀ Oracle中的类型类型有很多种,主要可以分为以下⼏类:1、字符串类型。
如:char、nchar、varchar2、nvarchar2。
2、数值类型。
如:int、number(p,s)、integer、smallint。
3、⽇期类型。
如:date、interval、timestamp。
4、PL/SQL类型。
如:pls_integer、binary_integer、binary_double(10g)、binary_float(10g)、boolean。
plsql类型是不能在sql环境中使⽤的,⽐如建表时。
5、⾃定义类型:type / create type。
⼆ type / create type 区别联系相同:可⽤⽤关键字create type 或者直接⽤type定义⾃定义类型,区别:create type 变量 as table of 类型--create type 变量 as object(字段1 类型1,字段2 类型2);--------------------------与 type 变量 is table of 类型--type 变量 is record(字段1 类型1,字段2 类型2);区别是⽤ create 后⾯⽤ as , 若直接⽤ type 后⾯⽤ iscreate 是创 object , ⽽ type 是创 record .另 type⽤在语句块中,⽽create 是的独⽴的.⼀般定义object的语法:⽤create type ⾃定义表类型A as table of ⾃定义Object类型A和create type ⾃定义Object类型A as object(字段1 类型1,字段2 类型2);与type ⾃定义表类型B is table of 类型和type ⾃定义Object类型B is record(字段1 类型1,字段2 类型2);⾃定义类型⼀般分为两中,object类型和table类型.object类似于⼀个recored,可以表⽰⼀个表的⼀⾏数据,object的字段就相当与表的字段.⾃定义的table类型需要⽤的已经定义好的object类型.type ⾃定义Object类型B is record(字段1 类型1,字段2 类型2);3.1:什么是记录(Record)?由单⾏多列的标量构成的复合结构。
oracle数据库的number类型
oracle数据库的number类型(最新版)目录1.Oracle 数据库的 number 类型概述2.number 类型的特点和优势3.number 类型的存储和精度4.使用 number 类型时的注意事项5.number 类型的应用示例正文【1.Oracle 数据库的 number 类型概述】Oracle 数据库的 number 类型是一种用于表示数值的固定精度数据类型,它可以存储整数、小数或浮点数。
与其他数据类型相比,number 类型具有较高的精度和较小的存储空间,因此在需要高精度数值计算的场景中具有优势。
【2.number 类型的特点和优势】umber 类型具有以下特点和优势:- 固定精度:number 类型可以指定精度,如精确到小数点后几位,避免了浮点数计算中的精度损失问题。
- 存储空间小:相比于其他数据类型,如 float 或 double,number 类型占用的存储空间较小,可以节省数据库空间。
- 高精度计算:number 类型支持高精度的数值计算,适合对精度要求较高的场景。
【3.number 类型的存储和精度】在 Oracle 数据库中,number 类型有多种精度选项,如:- NUMBER(p,s):表示最多 p 位数字,其中 s 表示小数点后位数。
例如,NUMBER(10,2) 表示最多 10 位数字,小数点后最多 2 位。
- NUMBER(p):表示最多 p 位数字,默认小数点后位数为 0。
例如,NUMBER(10) 表示最多 10 位数字,没有小数部分。
- DECIMAL(p,s):表示最多 p 位数字,其中 s 表示小数点后位数。
例如,DECIMAL(10,2) 表示最多 10 位数字,小数点后最多 2 位。
【4.使用 number 类型时的注意事项】在使用 number 类型时,需要注意以下几点:- 指定精度:要根据实际需求指定合适的精度,避免精度过高导致存储空间浪费或精度过低导致计算不准确。
oracle中number数据类型的格式规则
一、Number数据类型概述Oracle数据库中的Number数据类型是一种用于存储数字数据的数据类型。
它是一种非常灵活的数据类型,可以用来存储整数、小数、负数等各种类型的数字数据。
在Oracle数据库中,Number数据类型是非常常用的,因此了解其格式规则是非常重要的。
二、Number数据类型的格式规则1. 精度Number数据类型的精度指的是数字的总位数,包括小数点前面和后面的数字。
在定义Number数据类型时,可以指定其精度,如Number(10,2)表示总共10位数字,其中有2位是小数位。
精度最大可以达到38位,如果没有指定精度,默认是38位。
2. 小数位除了总位数外,Number数据类型还可以指定小数位的位数。
这样可以确保存储的数字都符合特定的小数精度要求。
如果没有指定小数位,默认是0,表示存储的数字为整数。
3. 范围Number数据类型可以存储的范围非常广泛,从极小的负数到极大的正数都可以涵盖。
在Oracle中,Number数据类型可以存储的范围是-1E-130到9.9E125。
4. 存储空间由于Number数据类型是可变精度的,因此其存储空间是动态分配的。
对于小的数字,所占用的存储空间会比较小;而对于大的数字,所占用的存储空间会比较大。
这种动态分配的特性可以节省存储空间,并且不会浪费空间。
5. 零值和空值在Oracle中,Number数据类型可以表示零值,并且可以存储空值。
这意味着Number数据类型可以完整地表示数字数据,并且可以保持数据的完整性。
6. 精度丢失在进行计算和存储数据时,由于Number数据类型的精度是有限的,可能会出现精度丢失的问题。
因此在使用Number数据类型时,需要注意保持数据的精度,避免出现数据计算不准确的情况。
三、Number数据类型的应用场景1. 金融行业在金融行业中,对于金额、利率、汇率等数字数据的精度要求非常高。
使用Number数据类型可以确保存储和计算这些数字数据时保持高精度,避免因精度丢失而引起的错误。
oracle中type类型
oracle中type类型摘要:1.Oracle中TYPE类型的概述2.TYPE类型的分类及特点3.创建和使用TYPE类型的方法4.举例说明TYPE类型的应用5.总结:TYPE类型在Oracle数据库中的重要性正文:在Oracle数据库中,TYPE类型是一种重要的数据类型,它允许用户自定义数据结构。
TYPE类型可以根据需求进行分类,并在应用程序中灵活使用。
本文将详细介绍TYPE类型的概念、分类、创建和使用方法,并通过实例演示其在实际应用中的优势。
1.Oracle中TYPE类型的概述在Oracle数据库中,TYPE类型是一种用户自定义的数据类型,它可以包含一个或多个字段,以及这些字段的约束条件。
TYPE类型是基于PL/SQL(过程式语言)实现的,允许开发人员根据需求创建和使用具有特定结构的数据类型。
2.TYPE类型的分类及特点根据包含的字段类型和约束条件,TYPE类型可以分为以下几种:(1)复合类型(Composite Type):复合类型可以包含多个字段,这些字段可以是不同的数据类型。
例如,可以创建一个包含字符串和整数字段的复合类型。
(2)集合类型(Collection Type):集合类型用于表示一组相同数据类型的元素。
例如,可以创建一个字符串类型的集合,用于存储多个字符串值。
(3)参数化类型(Parametric Type):参数化类型是基于一个或多个参数的类型,这些参数可以是已知的或未知的数据类型。
例如,可以创建一个基于整数类型参数的复合类型。
(4)内置类型(Built-in Type):Oracle数据库提供了一些内置的TYPE 类型,如DATE、TIMESTAMP等,这些类型具有特定的数据结构和约束条件。
3.创建和使用TYPE类型的方法创建TYPE类型的语法如下:```CREATE TYPE type_name IS (column1 data_type1,column2 data_type2,...);```其中,type_name表示TYPE类型的名称,column1、column2等表示TYPE类型的字段,data_type1、data_type2等表示字段的数据类型。
Oracle数据库基础
Oracle数据库基础一.Oracle的数据类型1.字符型用来存储字符串或字符数据,主要类型有varchar2、char和long。
①varchar2用来存储可变长的字符串或字符型数据,在使用时,须指明其最大字节数据。
②char用来存储定长字符串或字符型数据,使用时也要指定长度,其缺省值为1。
③long用来存储可变长的字符串或字符型数据。
2.数字型数字型用于存储整数或实数。
主要有:number、binary_integer①number用于存储数字数据,包括整数或浮点数。
在实际应用中,应该指定该类型数据长度和小数的位数。
在Oracle中其指定的长度不包含小数点和符号位。
②binary_integer它是PL/SQL的一个数据类型,它用于带符号的整数值,以2的补码的二进制形式进行存储。
3.日期型DATE型用于存储日期和事件信息,包括世纪、年、月、日、时、分、秒,其占7个字节,每一部分占一个字节。
4.raw和long rawraw和long raw用来存储二进制数据。
①rawRaw类似于char,必须指定存储二进制数的最大字节书。
②long rawlong raw类似于long。
5.ROWID数据库表中的每一行(ROW)都有一个地址,通过查询伪例ROWID获得该行地址。
该伪例的值为16进制字符串,该串的数据类型为ROWID。
其字符值的形式为:BLOCK.ROW.FILE。
6.布尔型在表中无布尔型的字段类型,只有在PL/SQL中可以定义BOOLEAN型,它的值为TRUE、FALSE、NULL。
在定义BOOLEAN 型变量时可限定变量为NOT NULL,但此时必须为该变量初始化。
7.复合类型①记录记录定义的格式如下:TYPE Record_type IS RECORD(Field1 Datatype1 [NOT NULL][:=Expression1],Field2 Datatype2 [NOT NULL][:=Expression2],…);在上述格式中Record_type是一种定义的记录类型。
oracle 中binary 类型
oracle 中binary 类型摘要:1.Oracle 中二进制类型的概念2.Oracle 中二进制类型的种类3.Oracle 中二进制类型的应用4.Oracle 中二进制类型的优缺点正文:在Oracle 数据库中,二进制类型是一种用于存储二进制数据的数据类型。
它可以存储各种类型的二进制数据,如图片、音频、视频等。
在Oracle 中,二进制类型为BLOB(Binary Large OBjects)。
Oracle 中的二进制类型主要有以下几种:1.BLOB:BLOB 类型用于存储较大的二进制数据,如图片和音频文件等。
它可以存储的最大长度为4GB。
2.CLOB:CLOB 类型用于存储较大的文本数据和二进制数据。
它的最大长度为2GB。
3.NCLOB:NCLOB 类型用于存储Unicode 字符集的文本数据和二进制数据。
它的最大长度为2GB。
4.BINARY_LARGE_OBJECTS:这种类型用于存储非常大的二进制数据,其最大长度可以达到4TB。
二进制类型在Oracle 中有广泛的应用,它可以用于存储各种类型的文件,如图片、音频、视频等。
同时,它也可以与其他数据类型进行组合,从而形成更加复杂的数据类型。
使用二进制类型也有一些优缺点。
优点在于它可以存储各种类型的二进制数据,并且可以存储大量的数据。
缺点在于,由于二进制数据通常较大,因此会对数据库的性能产生影响。
同时,二进制数据的处理和存储也需要更多的资源。
总的来说,Oracle 中的二进制类型为数据库管理员和开发者提供了一种存储和处理二进制数据的有效方式。
数据类型说明SIDNUMBER会...
O r a c l e9i动态性能(V$)视图说明本节介绍动态性能视图。
这些视图一般作为V$视图引用。
本节包括下列内容:动态性能视图。
视图说明。
C.1动态性能视图Oracle服务器包括一组基础视图,这些视图由服务器维护,系统管理员用户SYS可以访问它们。
这些视图被称为动态性能视图,因为它们在数据库打开和使用时不断进行更新,而且它们的内容主要与性能有关。
虽然这些视图很像普通的数据库表,但它们不允许用户直接进行修改。
这些视图提供内部磁盘结构和内存结构方面的数据。
用户可以对这些视图进行查询,以便对系统进行管理与优化。
文件CATALOG.SQL包含这些视图的定义以及公用同义词。
必须运行CATALOG.SQL创建这些视图及同义词。
C.1.1V$视图动态性能视图由前缀V_$标识。
这些视图的公用同义词具有前缀V$。
数据库管理员或用户应该只访问V$对象,而不是访问V_$对象。
动态性能视图由企业管理器和Oracle Trace使用,Oracle Trace是访问系统性能信息的主要界面。
建议:一旦实例启动,从内存读取数据的V$视图就可以访问了。
从磁盘读取数据的视图要求数据库已经安装好了。
警告:给出动态性能视图的有关信息只是为了系统的完整性和对系统进行管理。
公司并不承诺以后也支持这些视图。
C.1.2GV$视图在Oracle中,还有一种补充类型的固定视图。
即GV$(Global V$,全局V$)固定视图。
对于本章介绍的每种V$视图(除V$CACHE_LOCK、V$LOCK_ACTIVITY、V$LOCKS_WITH_COLLISIONS和V$ROLLNAME外),都存在一个GV$视图。
在并行服务器环境下,可查询GV$视图从所有限定实例中检索V$视图的信息。
除V$信息外,每个GV$视图拥有一个附加的名为INST_I D的整型列。
INST_ID列显示从其获得相关的V$视图信息的实例号。
INST_ID列可用作一个从可得到的实例集检索V$信息的过滤器。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Built-In Datatype Summary
一、概述
标量(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对数据库外存储的大型二进制文本进行只读形式的访问。
六、其他
其实在完成对标量变量的理解之后,基本上可以应付C/S模式下的常规数据库应用所需了,后续的类型说实话,我玩了5年ORACLE,都很少用到。
附:参考书《ORACLE8 PL/SQL程序设计》(《ORACLE8 PL/SQL PROGRAMMING》) ORACLE技术系列丛书机械工业出版社注:本文所列举的是PL/SQL当中可以定义的数据类型,并不是所有的类型都可以在建表时指定为列的数据类型。