字符数据类型

char数据类型

  当需要固定长度时,使用char数据类型,此数据类型长度可以使1-2000字节.若是不指定大小默认占1字节,如果长度有空余时会以空格进行填充,如果大于设定长度

数据库则会返回错误报告

nchar数据类型

  nchar,即国家字符集,使用方法和char相同.如果开发的项目需要国际化那么就选择nchar数据类型,nchar()和char()的区别在于nchar用来存储Unicode字符集类型,

即双字节字符数据.如:定义char和nchar长度分别为1,前者占1字节,后者占2字节.那么就意味着长度为1的char是不能存储中文.当然最主要的原因如下

NChar:将Unicode编码还原成对应的字符

Char:将ASC码还原成对应的字符

varchar2数据类型

  varchar2数据类型支持可变长度的字符串.该字符数据类型的大小为1~4000字节.在定义该数据类型时需指定其大小.与char类型相比,使用varchar2数据类型可以节省自盘空间

  如当长度不固定的时候varchar2会自动缩减,char则会以空格进行填充.但char的存取数度还是要比varchar2要快得多,因为其长度固定,方便程序的存储与查找;但是

char也为此付出的是空间的代价,因为其长度固定,所以难免会有多余的空格占位符占据空间,可谓是以空间换取时间效率,而varchar2是以空间效率为首位的.

  因此oracle中长度固定都是选char进行存储,不固定选择varchar2

varchar和varchar2的区别

  1.varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;
  2.VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;
  3.VARCHAR2字符要用几个字节存储,要看数据库使用的字符集,

一般建议使用varchar2,为了保证更好的兼容性

数值类型

number数据类型

  number数据类型可以存储正数,负数,0,定点数和精度为38为的浮点数,该数据类型格式为

    number(p.s)

  其中,p表示精度,标书有效的位数,在1~38之间.有效数:从左边第一个不为0的数算起,小数点和负号不计入有效数.

s为范围,表示小数点右边数字的位数,它在- 84 ~ +127之间

  规则:首页精确到小数点右边S位也就是小数部分,超出的四舍五入.如果精确后的有效位数小于等于p,则正确,否则报错

  如下栗子:

实际数据 数据类型 结果 说明
123.12  number(4,2) 错误 精确到小数点右边2位值为123.12,有效数为5大于4所以出错
12.789 number(4,2) 12.19 精确到小数点右边2位值为12.79,有效数4所以是12.19
1 number(3,4) 错误 精确到小数点右边4位值为1.0000,有效为5大于3所以出错
0.1 number(3,4) 错误 精确到小数点右边4位值为0.1000,有效数为4大于3所以出错
0.01 number(3,4) 0.0100 精确到小数点右边4位值为0.0100,有效数3所以是0.0100
0.00001 number(3,4) 0.0000 精确到小数点右边4位值为0.0000,有效数0所以是0.0000

日期时间数据类型

data数据类型

  data数据类型用于存储表中的日期和时间数据.oracle数据库使用自己的格式存储日期,使用7字节固定长度,每个字节分别存储 世纪,年,月,日,小时,分,秒.

日期实际数据类型的值为公元前4712年1月1日到公元9999年12月31日.其中oracle中的sysdate函数的功能是返回当前日期和时间.

timestamp数据类型

  timestamp数据类型用于存储日期的年,月,日,小时,分,秒,其中秒值精确到小数点后6位,该数据类型同事包含时区信息.systimestamp函数的功能是返回当前日期,时间和时区

注意:查询的时候可能会遇到可是不正确的问题,如显示语言,显示格式的等.可能存放的格式是 yyyy-mm-dd hh24:mi:ss,而查询出来却是dd-mm-yy hh24:mi:ss,可能是字符集出了

问题,还有一个原因就是系统的环境变量没有设置问题.

  • 可以选择更新会话:alert session set nls_date_format='YYYY-MM-DD HH24:MI:SS';(但是只对当前窗口有效,不想每次都调就可设置环境变量)
  • 在系统变量中增加一个 

lob数据类型

  lob又称"大对象"数据类型,该数据类型可以存储多达4GB的非结构化信息,如声音剪辑,视频剪辑等等.lob允许对数据进行高效,随机分段访问.lob可以是外部的,也可以是内部的

,取决于它相对数据库的位置

  修改lob类型可以用SQL数据操纵语言来完成也可以通过PL/sql中提供的程序包DBMS_lob完成.一个表可以有多列lob类型.

clob

  该数据类型可以存储单字节字符数据和多字节数据.主要用于存储非结构化的xml文档,如新闻内容简介等大量文字内容文档

blob

  该数据类型能够存储大的二进制对象,如图像,声音,视频等等

bfile

  该数据类型能够将二进制存储在数据库外部的操作系统文件中,bfile列存储一个bfile定位器,指向与服务器文件系统上的二进制,支持最大文件为4GB

nclob

  该数据类型用于存储大的nchar字符数据,nchar数据类型同时支持固定宽度字符和可变宽字符(Unicode数据),用法类型clob,大小不得大于4GB

最新文章

  1. 优化Web中的性能
  2. 升级到Windows10
  3. 两个app 的合并
  4. HashMap 中的 entrySet()使用方法 2016.12.28
  5. linux挂载共享文件夹
  6. Jersey框架一:Jersey RESTful WebService框架简介
  7. 科大讯飞和Tizen-TTS语音合成引擎
  8. swift基本语法
  9. 04747_Java语言程序设计(一)_第1章_Java语言基础
  10. &简单使用记录
  11. [UIKit学习]05.关于plist
  12. SQLite 创建表(http://www.w3cschool.cc/sqlite/sqlite-create-table.html)
  13. CentOS7 docker试水
  14. yii2在控制器中调用另一个控制器方法
  15. AD域安装及必要设置
  16. jfinal框架学习过程
  17. springboot aop的execution 表达式详解
  18. time模块的使用
  19. python concurrent.futures.Threadpoolexcutor的有界队列和无界队列
  20. 向Windows内核驱动传递用户层定义的事件Event,并响应内核层的通知

热门文章

  1. ZK配置文件
  2. CentOS安装MySQL,(常规安装方式MySQL无法远程连接)
  3. asp.net MVC 4.0 Controller回顾——ModelBinding实现过程
  4. Lambda动态排序通用方法
  5. Python接入支付宝进行PC端支付
  6. 解决移动端浏览器页面 X轴横向滚动条问题
  7. 运用CSS3媒体查询判断iPhoneX、iPhoneXR、iPhoneXS MAX及横竖屏
  8. 【干货】Html与CSS入门学习笔记1-3
  9. meterpreter > run post/windows/capture/keylog_recorder
  10. OpenSSL context 的几个参数