Oracle系列:(9)三大類型轉換

來源:互聯網
上載者:User

標籤:oracle



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 hh24:mi:ss‘) from dual;

select to_char(sysdate,‘yyyy-mm-dd"今天是"day HH12:MI:SS AM‘) from dual;

650) this.width=650;" src="http://s4.51cto.com/wyfs02/M01/86/F7/wKiom1fP2Dyj8TDdAAAwi4fBv0w391.png" title="001.PNG" alt="wKiom1fP2Dyj8TDdAAAwi4fBv0w391.png" />


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的意思

650) this.width=650;" src="http://s1.51cto.com/wyfs02/M01/86/F7/wKiom1fP2NGxCkZHAAATQl5O1xo704.png" title="002.PNG" alt="wKiom1fP2NGxCkZHAAATQl5O1xo704.png" />


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‘);

650) this.width=650;" src="http://s3.51cto.com/wyfs02/M02/86/F8/wKiom1fP2X-RXnbsAAA0tpFAiuI192.png" title="003.PNG" alt="wKiom1fP2X-RXnbsAAA0tpFAiuI192.png" />


3、由字串轉向數值


使用to_number(‘字串‘)函數將字串‘123’轉成數字123

select to_number(‘123‘) from dual;

650) this.width=650;" src="http://s2.51cto.com/wyfs02/M00/86/F6/wKioL1fP2kCAHG6uAAAJ2OFGgls795.png" title="004.PNG" alt="wKioL1fP2kCAHG6uAAAJ2OFGgls795.png" />


注意:

select ‘123‘ + 123 from dual;

結果:246

select ‘123‘ || 123 from dual;

結果:123123

650) this.width=650;" src="http://s2.51cto.com/wyfs02/M02/86/F6/wKioL1fP2pjAQ_bRAAAQL5RcqyE861.png" title="005.PNG" alt="wKioL1fP2pjAQ_bRAAAQL5RcqyE861.png" />







Oracle系列:(9)三大類型轉換

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.