Oracle 包含:  标量 (SCALAR)、复合(COMPOSITE)、引用(REFERENCE)和LOB四种数据类型  一、scalar分为七个组:数字、字符、行、日期、行标识、布尔和可信。  数字: 它有三种基本类型,NUMBER、PLS-INTEGER和 BINARY-INTEGER。

NUMBER是以十进制格式进行储存的,它便于储存,但是电脑会自动将它转换为二进制运算。NUMBER的定义方式是NUMBER(P,S), p是精度 (precision),s是刻度范围(scale)。精度最大值为38,scale的取值范围为-84到127 。

p、s可以省略,例如NUMBER(5)、NUMBER。  定点数的精度(p)和刻度 (s)遵循以下规则:  当s>0时(s表示小数点右边的数字的个数):  当一个数的整数部分的长度 > p-s 时,Oracle就会报错  当一个数的小数部分的长度 > s 时,Oracle就会舍入。

当s p 时, p表示小数点后第s位向左最多可以有多少位数字,如果大于p则Oracle报错,小数点后s位向 右 的数字被舍入  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相同。

(varchar2是oracle提供的独特的数据类型,oracle保证在任何版本中该数据类型向上和向下兼容,但不保证varchar。因为 varchar是标准sql提供的数据类型,有可能随着sql标准的变化而改变,推荐用varchar2。)(CHAR如果存放字母数字占1个字节,存放 GBK编码的汉字存放2个字节,存放UTF-8编码的汉字占用3个字节;NCHAR根据所选字符集来定义存放字符的占用字节数,一般都为2个字节存放一个字符(不管字符或者汉字)。

同理VARCHAR2与NVARCHAR2的区别。)  行:包括RAW和LONG RAW两种类型。用来存储二进制数据,不会在字符集间转换。  RAW,类似于 CHAR,声明方式RAW(L),L为长度,以字节为单位,作为数据库列最大2000,作为变量最大32767字节。

LONG RAW,类似于LONG,作为数据库列最大存储2G字节的数据,作为变量最大32760字节。  (raw这种格式可以用来保存较小的图形文件或带格式的文本文件,如Miceosoft Word文档。raw是一种较老的数据类型,将来会逐渐被BLOB、CLOB、NCLOB等大的对象数据类型所取代。

long raw 无可变长二进制数据,最大长度是2GB。Oracle用这种格式来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件。在同一张表中不能同时有long类型和long raw类型,long raw也是一种较老的数据类型,将来会逐渐被BLOB、CLOB、NCLOB等大的对象数据类型所取代)  其它:  日期,只有一种类型--DATE,用来存储时间信息,站用7个字节(从世纪到秒),绝对没有“千年虫”问题。

行标识,只有一种类型 --ROWID,用来存储“行标识符”,可以利用ROWIDTOCHAR函数来将行标识转换成为字符。  布尔,只有一种类型 --BOOLEAN,仅仅可以表示TRUE、FALSE或者NULL。  可信,只有一种类型 --MLSLABEL,可以在TRUSTED ORACLE中用来保存可变长度的二进制标签。

在标准ORACLE中,只能存储NULL值。

以上是我对于这个问题的解答,希望能够帮到大家。

全部

oracle 数据类型是什么,oracle的数据类型有哪些?相关推荐

  1. oracle基于dblink创建视图,【案例】Oracle dblink 数据库连接dblink insert操作数据类型发生改变...

    天萃荷净 开发DBA反映Oracle数据库两库之间通过dblink相连.在使用DML语句insert插入数据时操作的数据类型发生了改变 1.Oracle insert列属性 [oracle@saas- ...

  2. 抽象数据类型,让Oracle数据库数据管理更加容易

    2. 抽象数据的引用. 当建立好抽象数据类型的时候,数据库管理员就可以向基本数据类型那样,引用抽象数据类型,包括在建立表或者对相关字段进行赋值的时候,都这么方便. 如在建立表的时候,可以把这个抽象数据 ...

  3. oracle中定义表类型数据,oracle 定义表字段域的数据类型

    /****************************************************************************/ >oracle定义表字段域的数据类型 ...

  4. oracle 中int字节,oracle 数据类型

    使用整数数据的精确数字数据类型. bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字).存储 ...

  5. oracle字符串提取函数,oracle字符串分割和提取函数定义

    oracle字符串分割和提取函数定义 oracle字符串分割和提取 分割 create or replace function Get_StrArrayLength ( av_str varchar2 ...

  6. oracle union详解,Oracle中的union和join

    有时候,我们需要把很多表的查询结果给合并在一起显示或者导出,有时候呢我们又需要几张表联合一些条件进行查询,所以我们常会用到join和union语句. 官方说明 包含UNION [ALL], INTER ...

  7. cast函数 oracle 日期_从Oracle到PG 该做的改造工作一个都不能少!

    作者  Iris   (PG深度爱好者) 一.项目描述 前段时间刚完成一个应用ORACLE改造的项目,数据体量比较大,业务改造的周期计划比较短,再加上自研分布式MYSQL对事务.存储过程等限制,所以应 ...

  8. oracle时区参考表,ORACLE 时区

    商业和数据库很多时候必须跨时区工作,从9i开始,oracle环境开始有了时区意识,通过指定数据库的时区和使用TIMESTAMP WITH TIME ZONE和TIMESTAMP WITH LOCAL ...

  9. oracle根据null排序,oracle 关于null值排序

    在oracle中根据字段来desc排序的话null值可能会在数据的最前面.然而有时候我们查看数据的时候并不希望能够在前面看到这些null值的排序数据. 因此我查了一下: 1.排序的时候运用nvl(). ...

  10. .net 链oracle,.net链数据库oracle

    Oracle开发与使用文章收藏 收集一些Oracle开发与使用文章,以便于后续查找. [基础类] 1.ORACLE函数大全 2.Orace常用函数 3.oracle 日期函数介绍 4.Oracle中常 ...

最新文章

  1. python使用matplotlib可视化subplots绘制子图、自定义几行几列子图,如果M行N列,那么最终包含M*N个子图、在指定的子图中添加可视化结果
  2. iphone降级_iOS 14升级体验与问题总结,附降级教程
  3. Sparkle: a free framework to automatically check for updates
  4. When IT meets Coupon
  5. 【ACM】最长公共子序列 - 动态规划
  6. 博客页面运行代码demo测试
  7. java数据集成是什么_数据集成 - BlueDavy之技术Blog - BlogJava
  8. Java中文编码转换与字节长度判断
  9. TortoiseGit 添加ssh key
  10. 北京林业大学matlab公选课,北林选课攻略
  11. Kafka-常见问题
  12. CC2530 实现无线串口
  13. golang not enough arguments in call to uuid.Must
  14. 光学红外雨量IFR202型传感器智慧检测雨量场景等行业
  15. android 内核调整工具,内核调谐器(Kernel Tuner)手机工具 for android v4.4.8 安卓版
  16. 企业数字化不是各自发展,而是全面SaaS化推进
  17. 谷歌的json解析器Gson在Android/Java中的常用工具类
  18. 全国计算机二级十七套Excel,计算机二级MSOffice十七套题.docx
  19. ucenter php版本,noxue/ucenter - Packagist
  20. MGRE GRE PPP协议综合运用

热门文章

  1. vue项目 使用百度云 cyberplayer.js插件方法
  2. 算法篇:1、算法起源
  3. java 打印菱形和空心菱形
  4. 华为南研所2014春季机试题目-2不能入住的房客数
  5. hadoop 3.x常用端口
  6. android 仿网易标签切换,高仿网易云音乐客户端的Home页面切换Tabhost-IT蓝豹
  7. CSDN博客专用动态图小程序的推荐---ScreentoGIF教程
  8. file.getOriginalFilename()
  9. linux打印机验证密码,HP LaserJet Pro打印机远程管理员密码泄露漏洞
  10. MPAndroidChart使用(BarChart为例)