濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題

SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題

熱門標(biāo)簽:優(yōu)質(zhì)地圖標(biāo)注 奧威地圖標(biāo)注多個地方 怎樣在地圖上標(biāo)注路線圖標(biāo) 千呼電銷機器人價格 武漢長沙外呼系統(tǒng)方法和技巧 智能語音外呼系統(tǒng)選哪家 百度地圖標(biāo)注不同路線 外呼系統(tǒng)電銷專用 京華物流公司地圖標(biāo)注

寫這篇文章的時候,還真不知道如何取名,也不知道這個該如何將其歸類。這個是同事遇到的一個案例,案例比較復(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)文檔的官方,如果按照官方文檔:


當(dāng)兩個不同數(shù)據(jù)類型的表達(dá)式用運算符組合后,優(yōu)先級較低的數(shù)據(jù)類型首先轉(zhuǎn)換為優(yōu)先級較高的數(shù)據(jù)類型。 如果此轉(zhuǎn)換不是所支持的隱式轉(zhuǎn)換,則返回錯誤。 對于組合具有相同數(shù)據(jù)類型的操作數(shù)表達(dá)式的運算符時,運算的結(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)。需要謹(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ù)類型隱式轉(zhuǎn)換問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • MySQL的隱式類型轉(zhuǎn)換整理總結(jié)
  • MySQL隱式類型的轉(zhuǎn)換陷阱和規(guī)則
  • 隱式轉(zhuǎn)換引起的sql慢查詢實戰(zhàn)記錄

標(biāo)簽:益陽 防疫戰(zhàn)設(shè) 銅仁 天水 來賓 七臺河 宿州 威海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題》,本文關(guān)鍵詞  SQL,Server,中的,數(shù)據(jù),類型,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server 中的數(shù)據(jù)類型隱式轉(zhuǎn)換問題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    商河县| 河北省| 临沧市| 桐庐县| 紫金县| 沧源| 达孜县| 岗巴县| 靖宇县| 江油市| 织金县| 乌拉特后旗| 乳源| 西峡县| 岫岩| 和静县| 陵川县| 广平县| 长宁县| 苏州市| 颍上县| 仙游县| 电白县| 嘉定区| 天峻县| 乐昌市| 历史| 铜梁县| 南靖县| 容城县| 嘉定区| 融水| 图们市| 江口县| 江北区| 阳泉市| 鲁山县| 黄浦区| 永昌县| 营口市| 天祝|