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)