Oracle数据类型

Wesley13
• 阅读 932

Oracle的数据类型有二十多种,包括字符串类型、数字类型、日期类型、LOB类型、LONG RAW& RAW类型、ROWID & UROWID类型。太多的数据类型很容易让初学者感到迷茫,在本文中,我将以程序员的视角,结合实际开发的需求来介绍Oracle的数据类型。

Oracle的数据类型虽然很多,但实用的只有以下几种:

1)字符串类型:char和varchar2,可表达任何字符串。

2)数字类型:number(m,n),可表达任何数字,m是数字的总长度,n是小数点后的位数,如果n为0则表示是一个整数。

3)日期类型:date,存放日期和时间,包括年(yyyy)、月(mm)、日(dd)、小时(hh24)、分(mi)、秒(ss)。

4)clob类型,存放单字节字符串或多字节字符串数据,如文本文件、xml文件。

5)blob类型,存放非结构化的二进制数据,如图片、音频、视频、office文档等。

6)rowid类型,存放表中记录在数据库中的物理地址。

一、字符串类型

在C/C++语言中用,字符串用双引号包含起来,在Oracle数据库中,字符串用单引号包含起来的,如下:

'www.freecplus.net'

'码农有道'

'一只傻傻鸟 '

1、固定长度的字符串

固定长度字符串用char表示,当存入数据内容的长度不够时,Oracle将在数据内容后面自动填充空格以达到其固定的长度,例如char(10)总是包含10字节信息。

char字段最多可以存储2000字节的内容。

2、变长度的字符串

变长度字符串用varchar2表示,与char类型不同,Oracle不会在数据内容后面填充任何内容。

varchar2字段最多可以存储4000字节的内容,从Oracle 12c版本开始,可以存储32767字节的内容。

3、char和varchar2的比较

char(10),如果存入'freecplus',在数据库中将存储'freecplus ',在最后补了一个空格。

varchar2(10),如果存入'freecplus',在数据库中将存储'freecplus',什么也不会补。

在实际应用中,我们并不希望Oracle给字符串后面补空格,那么是不是可以弃用char类型呢?不是,我们一般用char类型存放固定大小的数据内容,例如身份证号码,固定是18位的,用char(18)就非常合适,能用varchar2(18)可以存放身份证号码吗?当然可以,但是,char(18)的效率比varchar2(18)的效率要高很多。

总结一下,如果确定、肯定、一定、保证存入字符串的长度是固定不变的,例如性别、身份证号码、手机号码,用char类型,否则用varchar2类型,例如姓名、学历、地址、兴趣爱好等,char虽然死板,但是效率高。

4、汉字的存储

每个汉字占多少字节要看具体的编码方式,如UTF-8(1-3字节)、GB2312(2字节)、GBK(2字节)、GB18030(1、2、4字节)。

二、数字类型

Oracle用number类型来存放数字,该类型能存储精度最多达38位,远远高于编程语言中常规的 long int和double类型。

number( m,n),m表示总长度,n表示小数位的精度,如果存入的数据的小数位的精度超过了n,则取四舍五入后的值。

例如:number(10,3),10是总长度,3是小数后的位数,如123.456。

如果存入123.4567,实际际将是123.457。

如果存入12345679.899,总长度超出了10,Oracle将提示错误。

如果打算存入整数,用number(m)就可以了,m表示可以存入数据的最大位数。

三、日期类型

Oracle采用date类型表示日期和时间,这是一个7字节的固定宽度的数据类型,有7个属性,包括:世纪、世纪中哪一年、月份、月中的哪一天、小时、分钟和秒。

对编程语言来说,日期和时间是用字符串来显示和书写的,Oracle提供了to_date和to_char两个函数在date类型和字符串类型之间转换。

例如:

insert into T_GIRL(name,birthday) values('西施',to_date('2000-01-01 01:12:35','yyyy-mm-dd hh24:mi:ss'));
select name,to_char(birthday,'yyyy-mm-dd hh24:mi:ss') from T_GIRL where name='西施';

四、clob和blob类型

clob类型,变长的字符串大对象,最长可达4GB,clob可以存储单字节字符串或多字节字符串数据,clob被认为是一个更大的字符串。当数据库的字符集发生转换时,clob类型会受到影响。

blob类型,变长的二进制大对象,最长可达4GB,blob主要用于保存带格式的非结构化数据,如图片、音频、视频、Office文档等。当数据库的字符集发生转换时,blob类型不会受到影响,Oracle数据库不关心存放的是什么内容。

五、rowid类型

Oracle数据库中每个表的每行记录都有一个存储的物理位置,即表的rowid伪列,采用rowid作为where条件的访问效率最高。

rowid的访问效率虽然是最高的,但是,在实际应用中要谨慎,需要注意两个问题:

1)rowid存放的是表记录的物理位置,在数据整理、数据备份和迁移的时候,记录的物理位置会发生改变;

2)rowid是Oracle数据库专有的数据类型,与其它的数据库不兼容。

六、其它数据类型

在上面的内容中,介绍了Oracle最常用的数据类型,可以满足99%以上的应用场景。

Oracle提供了22中不同的SQL数据类型,其它的数据类型不一定实用,但我还是把它们全部列出来,大家了解一下,不必深入研究。二十年来,其它的数据类型我从未使用过。

char:定长字符串,会用空格填充来达到最大长度。非null的char(10)包含10个字节信息。char字段最多可以存储2000个字节信息。

nchar:包含unicode格式数据的定长字符串。nchar字段最多可存储2000字节的信息。

varchar2:是varchar的同义词。这是一个变长字符串,与char类型不同,它不会用空格将字段或变量填充至最大长度。varchar(10)可能包含0\~10字节的信息,最多可存储4000字节信息。从12c起,可以存储32767字节信息。

nvarchar2:包含unicode格式数据的变长字符串。最多可存储4000字节信息。从12c起,可以存储32767字节信息。

raw:一种变长二进制数据类型,采用这种数据类型存储的数据不会发生字符集转换。

number:能存储精度最多高达38位的数字。这种类型的数据会以变长方式来存储,长度在0\~22字节。

binary_float:32位单精度浮点数,可以支持至少6位精度,占用磁盘上5个字节的存储空间。

binary_double:64位双精度浮点数,可以支持至少15位精度,占用磁盘上9个字节的存储空间。

long:这种类型能存储最多2GB的字符数据

long raw:long raw类型能存储多达2GB的二进制信息

date:这是一个7字节的定宽日期/时间数据类型,其中包含7个属性:世纪、世纪中的哪一年、月份、月中的哪一天、小时、分钟、秒。

timestamp:这是一个7字节或11字节的定宽日期/时间数据类型,它包含小数秒。

timestamp with time zone:这是一个13字节的timestamp,提供了时区支持。

timestamp with local time zone:这是一个7字节或11字节的定宽日期/时间数据类型,在数据的插入和读取时会发生时区转换。

interval year to month:这是一个5字节的定宽数据类型,用于存储一个时段。

interval day to second:这是一个11字节的定宽数据类型,用于存储一个时段。将时段存储为天/小时/分钟/秒数,还可以有9位小数秒。

blob:这种类型能够存储最多4GB的数据。

clob:这种类型能够存储最多4GB的数据。当字符集发生转换时,这种类型会受到影响。

nclob:这种类型能够存储最多4GB的数据。当字符集发生转换时,这种类型会受到影响。

bfile:这种数据类型可以在数据库列中存储一个oracle目录对象和一个文件名,我们可以通过它来读取这个文件。

rowid:实际上是数据库表中行的地址,它有10字节长。

urowid:是一个通用的rowid,没有固定的rowid的表。

七、版权声明

C语言技术网原创文章,转载请说明文章的来源、作者和原文的链接。
来源:C语言技术网(www.freecplus.net)
作者:码农有道

如果这篇文章对您有帮助,请点赞支持,或在您的博客中转发我的文章,谢谢!!!
如果文章有错别字,或者内容有错误,或其他的建议和意见,请您留言指正,非常感谢!!!

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这