首页
/
每日頭條
/
科技
/
oracle 表達式與數據類型不同
oracle 表達式與數據類型不同
更新时间:2025-08-25 11:55:55
概述

在某些情況下,Oracle Server 會收到數據類型與預期的數據類型不同的數據。發生這種情況時,Oracle Server 可自動将該數據轉換為預期的數據類型。這種數據類型轉換可以由Oracle Server 隐式完成,也可以由用戶顯式完成。

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)1

在MySQL跟Oracle中,如果存在隐式的數據類型轉換,可能導緻無法命中索引,從而進行全表掃描的危險。


一、類型轉換規則:

MySQL類型轉換規則:

1、兩個參數至少有一個是NULL時,比較的結果也是 NULL,例外是使用 <=> 對兩個NULL做比較時會返回1,這兩種情況都不需要做類型轉換

2、兩個參數都是字符串,會按照字符串來比較,不做類型轉換

3、兩個參數都是整數,按照整數來比較,不做類型轉換

4、十六進制的值和非數字做比較時,會被當做二進制串

5、有一個參數是TIMESTAMP或DATETIME,并且另外一個參數是常量,常量會被轉換為timestamp

6、所有其他情況下,兩個參數都會被轉換為浮點數再進行比較

Oracle類型轉換規則:

1、對于insert和update操作,oracle将值轉換為受影響的的列的類型。

2、對于SELECT操作,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'


三、oracle/mysql如何隐式轉換

1、=号二邊的類型是否相同

2、如果=号二邊的類型不同,嘗試的去做轉換

3、在轉換時,要确保合法合理,否則轉換會失敗,例如: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;

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)2

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;

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)3

4、使用to_char(數值,'格式')函數将數值轉成字符串

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

select to_char(1234,'L9,999') from dual;

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)4

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;

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)5

注意:

select '123' 123 from dual;246

select '123' || 123 from dual;123123

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)6


覺得有用的朋友多幫忙轉發哦!後面會分享更多devops和DBA方面的内容,感興趣的朋友可以關注下~

oracle 表達式與數據類型不同(詳解oracle中三大類型與隐式數據類型轉換)7

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
淘寶定金會返還嗎
淘寶定金會返還嗎
不會。根據預售規則,定金不支持退款。若由于個人原因不需要了,無法強制賣家同意定金退回,但可以聯系商家協商處理。買賣雙方協商達成一緻後,由賣家開通定金退款入口,買家點擊申請退款,申請後系統自動同意退款。定金:定金是指當事人雙方為了保證債務的履行,約定由當事人方先行支付給對方一定數額的貨币作為擔保,定金...
2025-08-25
筆記本運行時噪音太大怎麼回事
筆記本運行時噪音太大怎麼回事
1、風扇問題:筆記本電腦隻有溫度達到了BIOS預定的極限時,風扇才開始轉動,而且時常還不是全力運轉,分成幾擋轉速來運行,這也是出于省電和降噪的目的考慮的。由于筆記本電腦使用的時間過長,風扇内部積存了大量的灰塵和髒物,當風扇轉動時由于灰塵的堵塞,聲音會特别大,甚至有時候髒物會纏住扇葉導緻風扇無法正常工...
2025-08-25
一加手機怎麼換全局主題
一加手機怎麼換全局主題
本期圖文教程是由一加7,Android10制作。1、打開一加手機,在功能列表中找到設置的功能。2、進入到設置後,在設置功能中找到,并且點擊顯示設置。3、進入顯示設置後,在顯示設置中可以找到主題設置的功能。4、選擇不同的主題模式,有彩色主題和白色主題以及暗色主題。5、調整完成後,就會發現當前的主題已經...
2025-08-25
絲瓜高産有什麼管理技術
絲瓜高産有什麼管理技術
1、基肥。基肥施在基肥溝中,條施,先施堆廄肥,再把化學肥料混合後施在堆廄肥上,然後小作畦,并敷蓋銀黑色塑料布。追肥每約3星期施一次為原則,追肥前先行畦溝灌水,待水分滲入畦内後再把追肥施在畦溝兩邊及畦底部。2、整地作畦。作高畦,趁土壤半幹濕時先按行距在植行上犁開闊而淺的基肥溝,施下基肥後先小作畦,然後...
2025-08-25
手機屏幕共享怎麼打開
手機屏幕共享怎麼打開
1、在待機頁面下,點擊【應用程序】。2、點擊【設定】。3、點擊【連接】,然後選擇【屏幕共享】即可。
2025-08-25
Copyright 2023-2025 - www.tftnews.com All Rights Reserved