Oracle系列:(9)三大类型转换
2016-09-07 17:19
225 查看
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'
number<----->varchar2/char<----->date
oracle如何隐式转换:
1)=号二边的类型是否相同
2)如果=号二边的类型不同,尝试的去做转换
3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月
0、隐匿转换
查询1980年12月17日入职的员工(方式一:日期隐示式转换)
1、转向字符串
1.1、由日期转向字符串
使用to_char(日期,'格"常量"式')函数将日期转成字符串
显示如下格式:2015 年 04 月 25 日 星期六
使用to_char(日期,'格式')函数将日期转成字符串,显示如格式:2015-04-25今天是星期六 15:15:15
1.2、由数值转向字符串
使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:$1,234
使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234
2、由字符串转向日期
使用to_date('字符串','格式')函数,查询1980年12月17日入职的员工(方式二:日期显式转换)
3、由字符串转向数值
使用to_number('字符串')函数将字符串‘123’转成数字123
注意:
(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'
number<----->varchar2/char<----->date
oracle如何隐式转换:
1)=号二边的类型是否相同
2)如果=号二边的类型不同,尝试的去做转换
3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月
0、隐匿转换
查询1980年12月17日入职的员工(方式一:日期隐示式转换)
select * from emp where hiredate = '17-12月-80';
1、转向字符串
1.1、由日期转向字符串
使用to_char(日期,'格"常量"式')函数将日期转成字符串
显示如下格式:2015 年 04 月 25 日 星期六
select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;
使用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;
1.2、由数值转向字符串
使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:$1,234
select to_char(1234,'$9,999') from dual;
使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234
select to_char(1234,'$9,999') from dual; select to_char(1234,'L9,999') from dual;注意:L代表Locale的意思
2、由字符串转向日期
使用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');
3、由字符串转向数值
使用to_number('字符串')函数将字符串‘123’转成数字123
select to_number('123') from dual;
注意:
select '123' + 123 from dual;结果:246
select '123' || 123 from dual;结果:123123
相关文章推荐
- .Net程序员学用Oracle系列(5):三大数据类型
- oracle三大类型(varchar2,number,date)转换
- 深入Atlas系列:Web Sevices Access in Atlas示例(5) - 自定义TypeConverter把基础类型转换为复杂类型
- oracle中日期类型与unix 时间戳的转换
- oracle String类型转换成blob类型插入
- MySQL与Oracle数据类型转换
- Oracle中把integer转换成date类型
- 泛型技巧系列:如何提供类型参数之间的转换
- 数据库时间类型转换(Oracle、SQLServer)
- sybase中的text类型数据在oracle下转换为BLOB类型
- Oracle的数据类型和SQLServer的数据类型转换
- Oracle的数据类型转换 to_char(date)
- 深入Atlas系列:Web Sevices Access in Atlas示例(5) - 自定义TypeConverter把基础类型转换为复杂类型
- oracle中日期类型与unix 时间戳的转换
- Oracle中常见数据类型转换
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- Oracle Long类型转换为Clob类型
- Microsoft .NET Framework 2.0 Application Development Foundation 翻译系列8(第一章:第四课 类型转换)
- Oracle转换时间类型
- dorado前台的datetime与oracle的date类型转换