oracle三大类型(varchar2,number,date)转换

oracle中三大类型与隐式数据类型转换
(1)varchar2变长/char定长-->number,例如:'123'->123
(2)varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'
(3)number---->varchar2/char,例如:123->'123'
(4)date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'

oracle如何隐式转换:
1)=号二边的类型是否相同
2)如果=号二边的类型不同,尝试的去做转换
3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月
 
【1】查询1980年12月17日入职的员工(方式一:日期隐示式转换)
select * from emp where hiredate = '17-12月-80';
【2】使用to_char(日期,'格"常量"式')函数将日期转成字符串,显示如下格式:2015 年 04 月 25 日 星期六
select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;
【3】使用to_char(日期,'格式')函数将日期转成字符串,显示如格式:2015-04-25今天是星期六 15:15:15
select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss') from dual;

select to_char(sysdate,'yyyy-mm-dd"今天是"day HH12:MI:SS AM') from dual;
【4】使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:$1,234
select to_char(1234,'$9,999') from dual;
【5】使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234select to_char(1234,'$9,999') from dual;
select to_char(1234,'L9,999') from dual;
【6】使用to_date('字符串','格式')函数,查询1980年12月17日入职的员工(方式二:日期显式转换)
select * from emp where hiredate = to_date('1980年12月17日','yyyy"年"mm"月"dd"日"');

select * from emp where hiredate = to_date('1980#12#17','yyyy"#"mm"#"dd');

select * from emp where hiredate = to_date('1980-12-17','yyyy-mm-dd');
【7】使用to_number('字符串')函数将字符串‘123’转成数字123
select to_number('123') from dual;
注意:
select '123' + 123 from dual;246

select '123' || 123 from dual;123123


SQL数据类型
-----------------------------------

以表格形式说明:
 
字段类型     描述    
 bit      0或1的整型数字    
 int      从-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型数字    
 smallint      从-2^15(-32,768)到2^15(32,767)的整型数字    
 tinyint      从0到255的整型数字    
           
 decimal      从-10^38到10^38-1的定精度与有效位数的数字    
 numeric      decimal的同义词    
           
 money      从-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的货币数据,最小货币单位千分之十    
 smallmoney      从-214,748.3648到214,748.3647的货币数据,最小货币单位千分之十    
           
 float      从-1.79E+308到1.79E+308可变精度的数字    
 real      从-3.04E+38到3.04E+38可变精度的数字    
           
 datetime      从1753年1月1日到9999年12日31的日期和时间数据,最小时间单位为百分之三秒或3.33毫秒    
 smalldatetime      从1900年1月1日到2079年6月6日的日期和时间数据,最小时间单位为分钟    
           
 timestamp      时间戳,一个数据库宽度的唯一数字    
 uniqueidentifier      全球唯一标识符GUID    
           
 char      定长非Unicode的字符型数据,最大长度为8000    
 varchar      变长非Unicode的字符型数据,最大长度为8000    
 text      变长非Unicode的字符型数据,最大长度为2^31-1(2G)    
           
 nchar      定长Unicode的字符型数据,最大长度为8000    
 nvarchar      变长Unicode的字符型数据,最大长度为8000    
 ntext      变长Unicode的字符型数据,最大长度为2^31-1(2G)    
           
 binary      定长二进制数据,最大长度为8000    
 varbinary      变长二进制数据,最大长度为8000    
 image      变长二进制数据,最大长度为2^31-1(2G)



Oracle数据类型
-----------------------------------
VARCHAR2(size)   可变长度的字符串,其最大长度为size个字节;size的最大值是4000,而最小值是1;你必须指定一个VARCHAR2的size;   

NVARCHAR2(size)   可变长度的字符串,依据所选的国家字符集,其最大长度为size个字符或字节;size的最大值取决于储存每个字符所需的字节数,其上限为4000;你必须指定一个NVARCHAR2的
size;   

NUMBER(p,s)   精度为p并且数值范围为s的数值;精度p的范围从1到38;数值范围s的范围是从-84到127;

例如:NUMBER(5,2)   表示整数部分最大3位,小数部分为2位;

NUMBER(5,-2)   表示数的整数部分最大为7其中对整数的倒数2位为0,前面的取整。

NUMBER   表示使用默认值,即等同于NUMBER(5);   

LONG   可变长度的字符数据,其长度可达2G个字节;   

DATE   有效日期范围从公元前4712年1月1日到公元后4712年12月31日   

RAW(size)   长度为size字节的原始二进制数据,size的最大值为2000字节;你必须为RAW指定一个size;   

LONG   RAW   可变长度的原始二进制数据,其最长可达2G字节;   

CHAR(size)   固定长度的字符数据,其长度为size个字节;size的最大值是2000字节,而最小值和默认值是1;   

NCHAR(size)   也是固定长度。根据Unicode标准定义   

CLOB   一个字符大型对象,可容纳单字节的字符;不支持宽度不等的字符集;最大为4G字节   

NCLOB   一个字符大型对象,可容纳单字节的字符;不支持宽度不等的字符集;最大为4G字节;储存国家字符集   

BLOB   一个二进制大型对象;最大4G字节   

BFILE   包含一个大型二进制文件的定位器,其储存在数据库的外面;使得可以以字符流I/O访问存在数据库服务器上的外部LOB;最大大小为4G字节.

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值