转换为二进制数注意点

       将 int、smallint 和 tinyint 转换为 binary 或 varbinary,但是如果将 binary 转换回整数值,则在发生了截断的情况下此值将不同于原始整数值。
  
  例如:
  1.SELECT CAST( 123456 AS BINARY(4) )
  
  SELECT 语句显示整数值 123456 通常被存储为二进制值 0x0001e240


  
  
  2.SELECT CAST( 123456 AS BINARY(2) )
  
  SELECT 语句显示如果 binary 目标太小而不能保存整个值,则前导数字会被自动截断,以使该数值存储为 0xe240


  
  
  3.以下批处理显示,这种自动截断会影响算术运算而不产生错误:
  
  DECLARE @BinaryVariable2 BINARY(2)

  SET @BinaryVariable2 = 123456
  SET @BinaryVariable2 = @BinaryVariable2 + 1
  SELECT CAST( @BinaryVariable2 AS INT)
  GO
  
  最终结果为 57921,而不是 123457。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值