您好,登錄后才能下訂單哦!
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日入職的員工(方式一:日期隱示式轉換)
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 hh34: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
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。