手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >一个函数解决SQLServer中bigint 转 int带符号时报错问题
一个函数解决SQLServer中bigint 转 int带符号时报错问题
摘要:有一个需求是要在一个云监控的状态值中存储多个状态(包括可同时存在的各种异常、警告状态)使用了位运算机制在一个int型中存储。现在监控日志数据...

有一个需求是要在一个云监控的状态值中存储多个状态(包括可同时存在的各种异常、警告状态)使用了位运算机制在一个int型中存储。

现在监控日志数据量非常大(亿级别)需要对数据按每小时、每天进行聚合,供在线报表使用。

状态分了3个级别:正常(0)、警告(1)、异常(2),聚合时需要使用max选择最差的状态,就需要对状态值进行处理加上级别和状态位个数,就要借助bigint型来做运算了,

问题是再将bigint 转为 int时获取原始状态值时,SQLServer报错了:

消息 8115,级别 16,状态 2,第 1 行

将 expression 转换为数据类型 int 时出现算术溢出错误。

因为状态码中已经用到了 0x80000000, 出现了符号位的问题。

写了一个转换函数解决了。

CREATE FUNCTION [dbo].[BigintToInt] ( @Value bigint ) RETURNS int AS BEGIN -- 是否有int符号位 IF @Value & 0x80000000 <> 0 RETURN @Value & 0xFFFFFFFF | 0xFFFFFFFF00000000 -- 无符号位 RETURN @Value & 0xFFFFFFFF END

【一个函数解决SQLServer中bigint 转 int带符号时报错问题】相关文章:

远程连接局域网内的SQL Server 的方法

sql server中的decimal或者numeric的精度问题

列出SQL Server中具有默认值的所有字段的语句

SQL Server 2008 R2 应用及多服务器管理

SQL Server 2008 阻止保存要求重新创建表的更改问题的设置方法

SQLServer和Oracle常用函数对比

SQL Server中临时表与表变量的区别

SQL Server连接中三个常见的错误分析

SQLServer分布式事务问题

如何解决SQL Server警报的疑难问题

精品推荐
分类导航