詳解Oracle中三大類型與隱式數據類型轉換
在某些情況下,Oracle Server 會收到數據類型與預期的數據類型不同的數據。發生這種情況時,Oracle Server 可自動將該數據轉換為預期的數據類型。這種數據類型轉換可以由Oracle Server 隱式完成,也可以由用戶顯式完成。
在MySQL跟Oracle中,如果存在隱式的數據類型轉換,可能導致無法命中索引,從而進行全表掃描的危險。
一、類型轉換規則
MySQL類型轉換規則:
- 兩個參數至少有一個是NULL時,比較的結果也是 NULL,例外是使用 <=> 對兩個NULL做比較時會返回1,這兩種情況都不需要做類型轉換
- 兩個參數都是字符串,會按照字符串來比較,不做類型轉換
- 兩個參數都是整數,按照整數來比較,不做類型轉換
- 十六進制的值和非數字做比較時,會被當做二進制串
- 有一個參數是TIMESTAMP或DATETIME,并且另外一個參數是常量,常量會被轉換為timestamp
- 所有其他情況下,兩個參數都會被轉換為浮點數再進行比較
Oracle類型轉換規則:
- 對于insert和update操作,oracle將值轉換為受影響的的列的類型。
- 對于SELECT操作,oracle會將列的值的類型轉換為目標變量的類型。
二、Oracle中三大類型與隱式數據類型轉換
- varchar2變長/char定長-->number,例如:'123'->123
- varchar2/char-->date,例如:'25-4月-15'->'25-4月-15'
- number---->varchar2/char,例如:123->'123'
- date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'
三、Oracle/MySQL如何隱式轉換
- =號二邊的類型是否相同
- 如果=號二邊的類型不同,嘗試的去做轉換
- 在轉換時,要確保合法合理,否則轉換會失敗,例如:12月不會有32天,一年中不會有13月
四、Oracle隱式轉換實例
(1) 查詢1980年12月17日入職的員工(方式一:日期隱示式轉換)
- select * from emp where hiredate = '17-12月-80';
(2) 使用to_char(日期,'格"常量"式')函數將日期轉成字符串)
- select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;
(3) 使用to_char(日期,'格式')函數將日期轉成字符串)
- 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(數值,'格式')函數將數值轉成字符串
- select to_char(1234,'$9,999') from dual;
- select to_char(1234,'L9,999') from dual;
(5) 使用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');
(6) 使用to_number('字符串')函數將字符串‘123’轉成數字123
- select to_number('123') from dual;
注意:
- select '123' + 123 from dual;246
- select '123' || 123 from dual;123123