SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題
寫這篇文章的時候,還真不知道如何取名,也不知道這個該如何將其歸類。這個是同事遇到的一個案例,案例比較復(fù)雜,這里抽絲剝繭,僅僅構(gòu)造一個簡單的案例來展現(xiàn)一下這個問題。我們先構(gòu)造測試數(shù)據(jù),如下所示:
CREATE TABLE TEST
(
ID INT,
GOOD_TYPE VARCHAR(12),
GOOD_WEIGHT NUMERIC(18,2)
)
INSERT INTO dbo.TEST
VALUES( 1, 'T1',1.27)
SELECT GOOD_TYPE,
CASE WHEN ( GOOD_TYPE = 'T1' ) THEN 99.1 + SUM(GOOD_WEIGHT)
ELSE CEILING(SUM(GOOD_WEIGHT))
END AS GrossWeight ,
SUM(GOOD_WEIGHT) AS NetWeight
FROM dbo.TEST
GROUP BY GOOD_TYPE;
如上所示,為什么99.1 + SUM(GOOD_WEIGHT)變成100了呢? 原始SQL非常復(fù)雜,我們分析、排除掉各個因素后,始終不得要領(lǐng),各種折騰中發(fā)現(xiàn),如果這樣轉(zhuǎn)換一下(請見下面截圖),居然就OK了,后面分析了一下,應(yīng)該是CASE WHEN里面的不同數(shù)據(jù)類型導(dǎo)致隱式轉(zhuǎn)換,說實話之前還真沒有留意CASE WHEN中存在數(shù)據(jù)類型的隱性轉(zhuǎn)換,但是為什么就一定從NUMERIC轉(zhuǎn)換為INT了呢? 而不是INT隱性轉(zhuǎn)換為NUMERIC呢, 說實話沒有看到相關(guān)文檔的官方,如果按照官方文檔:
當兩個不同數(shù)據(jù)類型的表達式用運算符組合后,優(yōu)先級較低的數(shù)據(jù)類型首先轉(zhuǎn)換為優(yōu)先級較高的數(shù)據(jù)類型。 如果此轉(zhuǎn)換不是所支持的隱式轉(zhuǎn)換,則返回錯誤。 對于組合具有相同數(shù)據(jù)類型的操作數(shù)表達式的運算符時,運算的結(jié)果便為該數(shù)據(jù)類型
而我們知道,Decimal 和 NUMERIC 是同義詞,可互換使用,而官方文檔“數(shù)據(jù)類型優(yōu)先級 (Transact-SQL)”中,Decimal的優(yōu)先級明顯高于INT,如果真要按照原理來解釋,應(yīng)該是INT轉(zhuǎn)換NUMERIC才對(兩種數(shù)據(jù)類型支持隱式轉(zhuǎn)換),所以越想越糊涂,只知道有這么一回事,但是真正的Root Cause尚不清楚,而且在精確度要求較高的報表中,這種現(xiàn)象就會類似Bug一樣的突然出現(xiàn)。需要謹慎留心!
參考資料:
總結(jié)
以上所述是小編給大家介紹的SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
SQL Server實時同步更新遠程數(shù)據(jù)庫遇到的問題小結(jié)
這篇文章主要介紹了SQL Server實時同步更新遠程數(shù)據(jù)庫遇到的問題小結(jié),需要的朋友可以參考下2017-04-04
SQL Server根據(jù)分區(qū)表名查找所在的文件及文件組實現(xiàn)腳本
這篇文章主要介紹了SQL Server根據(jù)分區(qū)表名查找所在的文件及文件組實現(xiàn)腳本,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-07-07
SQL Server 數(shù)據(jù)庫備份和還原認識和總結(jié)(二)
本文將針對上文繼續(xù)進行數(shù)據(jù)備份和還原講解,主要講解備份和還原的一些關(guān)鍵選項2012-08-08
sql?server?數(shù)據(jù)庫鎖教程及鎖操作方法
SQL?Server數(shù)據(jù)庫鎖機制是保證并發(fā)性和數(shù)據(jù)一致性的關(guān)鍵,它通過不同級別的鎖和鎖類型(共享、排他、更新等)來管理資源訪問,了解和正確使用鎖機制,可以幫助開發(fā)者設(shè)計高效、并發(fā)性強的數(shù)據(jù)庫應(yīng)用,本文介紹sql?server?數(shù)據(jù)庫鎖教程及鎖操作,感興趣的朋友一起看看吧2025-02-02
在SQL Server數(shù)據(jù)庫中為標識(IDENTITY)列插入顯式值
SQL Server中的標識列和ACCESS中的“自動編號”相似,都是插入記錄的時候自動生成,一般不允許也不需要我們?nèi)ナ謩有薷乃?/div> 2007-02-02最新評論



