T-SQL中的位翻转操作

Chr*_*ger 16 t-sql sql-server bit-manipulation

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

我如何完成以下任务:

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

我翻转之前的掩码值:143

翻转后的掩码值:399

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

Dav*_*d M 25

使用异或:

SELECT value ^ 256
Run Code Online (Sandbox Code Playgroud)

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

SELECT value ^ POWER(2, power)
Run Code Online (Sandbox Code Playgroud)

  • 你想翻转还是打开?翻转 - 使用异或(^); 打开 - 使用OR(|).如果您想要更优雅,请使用简洁命名的用户定义函数.:) (2认同)

Cha*_*ana 20

TSQL位运算符可以发现这里和如何使用这些好文章是在这里

  • 问题是关于位FLIPPING,而不是位移. (4认同)