T-SQL中的位翻转操作

时间:2009-07-10 15:16:32

标签: sql-server tsql bit-manipulation

我的数据库中有一个bitmasked int字段。通常我通过C#代码管理它,但现在我需要使用T-SQL

在掩码中翻转一下

如何完成以下任务:

  

我要翻转的位:1<< 8(256)

     

我翻转之前的掩码值:143

     

翻转后的掩码值:399

这可以在没有T-SQL中缺少的位运算符的情况下完成,对吧?

2 个答案:

答案 0 :(得分:25)

使用XOR:

SELECT value ^ 256

所以在你的情况下,SELECT 143 ^ 256确实会返回399.如果你想传入指数:

SELECT value ^ POWER(2, power)

答案 1 :(得分:20)

可以找到TSql Bitwise运算符here,有关如何使用它们的好文章是here