寫(xiě)這篇文章的時(shí)候,還真不知道如何取名,也不知道這個(gè)該如何將其歸類(lèi)。這個(gè)是同事遇到的一個(gè)案例,案例比較復(fù)雜,這里抽絲剝繭,僅僅構(gòu)造一個(gè)簡(jiǎn)單的案例來(lái)展現(xiàn)一下這個(gè)問(wèn)題。我們先構(gòu)造測(cè)試數(shù)據(jù),如下所示:
成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括巴東網(wǎng)站建設(shè)、巴東網(wǎng)站制作、巴東網(wǎng)頁(yè)制作以及巴東網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專(zhuān)注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,巴東網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶(hù)以成都為中心已經(jīng)輻射到巴東省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶(hù)的支持與信任!
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ù)雜,我們分析、排除掉各個(gè)因素后,始終不得要領(lǐng),各種折騰中發(fā)現(xiàn),如果這樣轉(zhuǎn)換一下(請(qǐng)見(jiàn)下面截圖),居然就OK了,后面分析了一下,應(yīng)該是CASE WHEN里面的不同數(shù)據(jù)類(lèi)型導(dǎo)致隱式轉(zhuǎn)換,說(shuō)實(shí)話(huà)之前還真沒(méi)有留意CASE WHEN中存在數(shù)據(jù)類(lèi)型的隱性轉(zhuǎn)換,但是為什么就一定從NUMERIC轉(zhuǎn)換為INT了呢? 而不是INT隱性轉(zhuǎn)換為NUMERIC呢, 說(shuō)實(shí)話(huà)沒(méi)有看到相關(guān)文檔的官方,如果按照官方文檔:

當(dāng)兩個(gè)不同數(shù)據(jù)類(lèi)型的表達(dá)式用運(yùn)算符組合后,優(yōu)先級(jí)較低的數(shù)據(jù)類(lèi)型首先轉(zhuǎn)換為優(yōu)先級(jí)較高的數(shù)據(jù)類(lèi)型。 如果此轉(zhuǎn)換不是所支持的隱式轉(zhuǎn)換,則返回錯(cuò)誤。 對(duì)于組合具有相同數(shù)據(jù)類(lèi)型的操作數(shù)表達(dá)式的運(yùn)算符時(shí),運(yùn)算的結(jié)果便為該數(shù)據(jù)類(lèi)型
而我們知道,Decimal 和 NUMERIC 是同義詞,可互換使用,而官方文檔“數(shù)據(jù)類(lèi)型優(yōu)先級(jí) (Transact-SQL)”中,Decimal的優(yōu)先級(jí)明顯高于INT,如果真要按照原理來(lái)解釋?zhuān)瑧?yīng)該是INT轉(zhuǎn)換NUMERIC才對(duì)(兩種數(shù)據(jù)類(lèi)型支持隱式轉(zhuǎn)換),所以越想越糊涂,只知道有這么一回事,但是真正的Root Cause尚不清楚,而且在精確度要求較高的報(bào)表中,這種現(xiàn)象就會(huì)類(lèi)似Bug一樣的突然出現(xiàn)。需要謹(jǐn)慎留心!
參考資料:
https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/data-type-precedence-transact-sql?view=sql-server-2017
https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/data-type-conversion-database-engine?view=sql-server-2017
總結(jié)
以上所述是小編給大家介紹的SQL Server 中的數(shù)據(jù)類(lèi)型隱式轉(zhuǎn)換問(wèn)題,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
分享題目:SQLServer中的數(shù)據(jù)類(lèi)型隱式轉(zhuǎn)換問(wèn)題
網(wǎng)站鏈接:http://chinadenli.net/article0/gesgoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、App開(kāi)發(fā)、軟件開(kāi)發(fā)、面包屑導(dǎo)航、網(wǎng)頁(yè)設(shè)計(jì)公司、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)