将 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。