SQLServer中bigint轉int帶符號時報錯問題解決方法
有一個需求是要在一個云監(jiān)控的狀態(tài)值中存儲多個狀態(tài)(包括可同時存在的各種異常、警告狀態(tài))使用了位運算機制在一個int型中存儲。
現(xiàn)在監(jiān)控日志數(shù)據(jù)量非常大(億級別)需要對數(shù)據(jù)按每小時、每天進行聚合,供在線報表使用。
狀態(tài)分了3個級別:正常(0)、警告(1)、異常(2),聚合時需要使用max選擇最差的狀態(tài),就需要對狀態(tài)值進行處理加上級別和狀態(tài)位個數(shù),就要借助bigint型來做運算了,
問題是再將bigint 轉為 int時獲取原始狀態(tài)值時,SQLServer報錯了:
消息 8115,級別 16,狀態(tài) 2,第 1 行
將 expression 轉換為數(shù)據(jù)類型 int 時出現(xiàn)算術溢出錯誤。
因為狀態(tài)碼中已經(jīng)用到了 0x80000000, 出現(xiàn)了符號位的問題。
寫了一個轉換函數(shù)解決了。
CREATE FUNCTION [dbo].[BigintToInt] ( @Value bigint ) RETURNS int AS BEGIN -- 是否有int符號位 IF @Value & 0x80000000 <> 0 RETURN @Value & 0xFFFFFFFF | 0xFFFFFFFF00000000 -- 無符號位 RETURN @Value & 0xFFFFFFFF END
相關文章
sql server編寫archive通用模板腳本實現(xiàn)自動分批刪除數(shù)據(jù)
這篇文章主要介紹了sql server編寫archive通用模板腳本實現(xiàn)自動分批刪除數(shù)據(jù),需要的朋友可以參考下2019-10-10
SQL Server中的排名函數(shù)與分析函數(shù)詳解
本文詳細講解了SQL Server中的排名函數(shù)與分析函數(shù),文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
SQL Server中通過擴展存儲過程實現(xiàn)數(shù)據(jù)庫的遠程備份與恢復
SQL Server中通過擴展存儲過程實現(xiàn)數(shù)據(jù)庫的遠程備份與恢復實現(xiàn)方法,需要的朋友可以參考下2012-05-05
sql更新語句中update set from用法實現(xiàn)
本文主要介紹了sql更新語句中update set from用法實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02
SQLServer中防止并發(fā)插入重復數(shù)據(jù)的方法詳解
本文主要介紹了SQLServer中防止并發(fā)插入重復數(shù)據(jù)的方法,具有很好的參考價值。下面跟著小編一起來看下吧2017-03-03
SQL Server在AlwaysOn中使用內存表的“踩坑”記錄
這篇文章主要給大家介紹了關于SQL Server在AlwaysOn中使用內存表的一些"踩坑"記錄,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習下吧。2017-09-09
Sql Server2012 使用IP地址登錄服務器的配置圖文教程
最近在使用NFineBase框架+c#做一個系統(tǒng)的時候,在使用sql server 2012 連接數(shù)據(jù)庫的時候,在使用過程中遇到了幾個問題,下面小編給大家分享Sql Server2012 使用IP地址登錄服務器的配置圖文教程,一起學習吧2017-07-07
SQL設置SQL Server最大連接數(shù)及查詢語句
今天遇到了關于Sql Server最大連接數(shù)(Max Pool Size)的問題,后來通過查找一些資料解決了,所以想著總結下關于SQL Server最大連接數(shù)的內容,所以這篇文章主要介紹了SQL設置SQL Server最大連接數(shù)與查詢語句,有需要的朋友們可以參考借鑒。2016-12-12

