oracle技能-格式转换

1.varchar转为number,用 to_number(列名):
select to_number(t.create_user) from 表名 t;
2.number转为varchar,用 to_char(列名):
select to_char(t.user_role_id) from 表名 t;
3.date转为varchar类型,用 to_char(列名,想要的日期格式):
select to_char(t.create_date,’yyyy-mm-dd’) 重点内容from 表名 t
4.varchar类型转date,用 to_date(列名,想要的日期格式):
insert into 表名 values(1,’lili’,to_date(‘2012-11-11’,’yyyy-mm-dd’));
5.CAST——类型转换
select cast(” as number) as a, ‘01’ as b from dual union
select 2 as a, ‘02’ as b from dual;

作者:java_mmt_sayno
来源:CSDN
原文:https://blog.csdn.net/java_mmt/article/details/81867514
版权声明:本文为博主原创文章,转载请附上博文链接!
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’

1、oracle如何隐式转换:

1)=号二边的类型是否相同

2)如果=号二边的类型不同,尝试的去做转换

3)在转换时,要确保合法合理,否则转换会失败,例如:12月不会有32天,一年中不会有13月

2、查询1980年12月17日入职的员工(方式一:日期隐示式转换)

select * from emp where hiredate = ‘17-12月-80’;

3、使用to_char(日期,‘格"常量"式’)函数将日期转成字符串,显示如下格式:2015 年 04 月 25 日 星期六

select to_char(sysdate,‘yyyy" 年 “mm” 月 “dd” 日 "day’) from dual;

4、使用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;

5、使用to_char(数值,‘格式’)函数将数值转成字符串,显示如下格式:$1,234

select to_char(1234,’$9,999’) from dual;

6、使用to_char(数值,‘格式’)函数将数值转成字符串,显示如下格式:¥1,234select to_char(1234,’$9,999’) from dual;

select to_char(1234,‘L9,999’) from dual;

7、使用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’);

8、使用to_number(‘字符串’)函数将字符串‘123’转成数字123

select to_number(‘123’) from dual;

注意:

select ‘123’ + 123 from dual;246

select ‘123’ || 123 from dual;123123

作者:LFSenior
来源:CSDN
原文:https://blog.csdn.net/qq_35448976/article/details/70355422
版权声明:本文为博主原创文章,转载请附上博文链接!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值