欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年08月28日 09:35:31   作者:瀟湘隱者  
這篇文章主要介紹了SQL Server 中的數據類型隱式轉換問題,本文給大家介紹的非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

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

 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ā)現,如果這樣轉換一下(請見下面截圖),居然就OK了,后面分析了一下,應該是CASE WHEN里面的不同數據類型導致隱式轉換,說實話之前還真沒有留意CASE WHEN中存在數據類型的隱性轉換,但是為什么就一定從NUMERIC轉換為INT了呢? 而不是INT隱性轉換為NUMERIC呢, 說實話沒有看到相關文檔的官方,如果按照官方文檔


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

而我們知道,Decimal NUMERIC 是同義詞,可互換使用,而官方文檔“數據類型優(yōu)先級 (Transact-SQL)”中,Decimal的優(yōu)先級明顯高于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 中的數據類型隱式轉換問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • SQL Server行轉列的方法解析

    SQL Server行轉列的方法解析

    本文主要介紹了SQL Server行轉列的方法解析。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • sql中返回參數的值

    sql中返回參數的值

    sql中返回參數的值...
    2007-03-03
  • 使用SQL語句創(chuàng)建觸發(fā)器的實例

    使用SQL語句創(chuàng)建觸發(fā)器的實例

    觸發(fā)器 是一種特殊類型的存儲過程,它不同于我們前面介紹過的存儲過程。存儲過程可以通過語句直接調用,而 觸發(fā)器主要是通過事件進行觸發(fā)而被執(zhí)行的,這篇文章主要介紹了使用SQL語句創(chuàng)建觸發(fā)器的實例,需要的朋友可以參考下
    2023-06-06
  • sql查詢結果列拼接成逗號分隔的字符串方法

    sql查詢結果列拼接成逗號分隔的字符串方法

    SQL查詢時會經常需要,把查詢的結果拼接成一個字符串。那么怎么直接把sql查詢結果列拼接成逗號分隔的字符串方法,下面就一起來了解一下
    2021-05-05
  • SQL查詢連續(xù)號碼段的巧妙解法

    SQL查詢連續(xù)號碼段的巧妙解法

    SQL查詢連續(xù)號碼段的巧妙解法...
    2007-04-04
  • 如何優(yōu)化SQL語句(全)

    如何優(yōu)化SQL語句(全)

    這篇文章主要介紹了如何優(yōu)化SQL語句(全),作為一名程序猿會寫SQL語句是最基本的要求,但是如何寫出性能比較高的SQL語句呢,下面小編給大家整理供大家參考,需要的朋友可以參考下
    2015-07-07
  • SQL 判斷字段類型語句

    SQL 判斷字段類型語句

    SQL 判斷字段類型語句實現代碼。
    2009-09-09
  • sqlserver常用命令行操作(啟動、停止、暫停)

    sqlserver常用命令行操作(啟動、停止、暫停)

    sqlserver常用命令行操作,方便在命令行實現sqlserver的啟動、停止、暫停
    2011-12-12
  • SQL 研究 相似的數據類型

    SQL 研究 相似的數據類型

    數據類型在精度,范圍上有較大的差別。選擇合適的類型可以減少table和index的大小,進而減少IO的開銷,提高效率。本文介紹基本的數值類型及其之間的細小差別。
    2009-07-07
  • SQL Server中執(zhí)行動態(tài)SQL

    SQL Server中執(zhí)行動態(tài)SQL

    本文詳細講解了SQL Server中執(zhí)行動態(tài)SQL的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05

最新評論