国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SQL Server 中的數據類型隱式轉換問題

2020-07-25 12:36:03
字體:
來源:轉載
供稿:網友

寫這篇文章的時候,還真不知道如何取名,也不知道這個該如何將其歸類。這個是同事遇到的一個案例,案例比較復雜,這里抽絲剝繭,僅僅構造一個簡單的案例來展現一下這個問題。我們先構造測試數據,如下所示:

 CREATE TABLE TEST(  ID INT,  GOOD_TYPE VARCHAR(12), GOOD_WEIGHT NUMERIC(18,2))INSERT INTO dbo.TESTVALUES( 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 NetWeightFROM dbo.TESTGROUP BY GOOD_TYPE;

如上所示,為什么99.1 + SUM(GOOD_WEIGHT)變成100了呢? 原始SQL非常復雜,我們分析、排除掉各個因素后,始終不得要領,各種折騰中發現,如果這樣轉換一下(請見下面截圖),居然就OK了,后面分析了一下,應該是CASE WHEN里面的不同數據類型導致隱式轉換,說實話之前還真沒有留意CASE WHEN中存在數據類型的隱性轉換,但是為什么就一定從NUMERIC轉換為INT了呢? 而不是INT隱性轉換為NUMERIC呢, 說實話沒有看到相關文檔的官方,如果按照官方文檔:


當兩個不同數據類型的表達式用運算符組合后,優先級較低的數據類型首先轉換為優先級較高的數據類型。 如果此轉換不是所支持的隱式轉換,則返回錯誤。 對于組合具有相同數據類型的操作數表達式的運算符時,運算的結果便為該數據類型

而我們知道,Decimal NUMERIC 是同義詞,可互換使用,而官方文檔“數據類型優先級 (Transact-SQL)”中,Decimal的優先級明顯高于INT,如果真要按照原理來解釋,應該是INT轉換NUMERIC才對(兩種數據類型支持隱式轉換),所以越想越糊涂,只知道有這么一回事,但是真正的Root Cause尚不清楚,而且在精確度要求較高的報表中,這種現象就會類似Bug一樣的突然出現。需要謹慎留心!

參考資料:

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

總結

以上所述是小編給大家介紹的SQL Server 中的數據類型隱式轉換問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 盐城市| 封开县| 正定县| 郯城县| 天峨县| 蓝田县| 嘉祥县| 贵定县| 屏东县| 碌曲县| 锡林郭勒盟| 民权县| 吉水县| 白城市| 兴隆县| 西乡县| 凌云县| 永和县| 玉林市| 古浪县| 东丰县| 临沂市| 长丰县| 衡阳市| 静宁县| 芦山县| 东源县| 靖西县| 射阳县| 西乡县| 慈溪市| 西畴县| 霞浦县| 抚顺市| 平武县| 英超| 广汉市| 庆阳市| 榆树市| 赣州市| 达孜县|