重要 每当执行任意类型的位运算时,位运算中所使用的表达式的存储长度是非常重要的。建议在存储值时,使用相同的字节数。例如,将十进制数 5 存储为 tinyint、smallint 或 int 数据类型时,所生成的值将用不同的字节数存储。tinyint 用 1 个字节存储数据,smallint 用 2 个字节存储数据,int 用 4 个字节存储数据。因此,与直接进行二进制或十六进制转换相比,在一个 int 数据类型的十进制数上执行位运算会产生不同的结果,当使用 ~(按位 NOT)运算符时,尤其如此。按位 NOT 运算可以对长度较小的变量执行操作,但是当该变量转换为较长的数据类型时,则高 8 位的值就有可能与期望的值不同。建议先将数据类型较小的变量转换为较大的数据类型,然后对所得的结果执行按位 NOT 运算。
示例
下面的示例创建一个具有 int 数据类型的表以显示值,并将该表放入一行中。
USE master
GO
IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME = 'bitwise')
DROP TABLE bitwise
GO
CREATE TABLE bitwise
(
a_int_value tinyint NOT NULL,
b_int_value tinyint NOT NULL
)
GO
INSERT bitwise VALUES (170, 75)
GO
下面的查询在 a_int_value 列和 b_int_value 列上执行按位 NOT 运算。
USE MASTER
GO
SELECT ~ a_int_value, ~ b_int_value
FROM bitwise