sql-server – T-SQL中的位翻转操作

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

我如何完成以下任务:

The bit I want to flip: 1 << 8 (256)

The mask value before I flip: 143

The mask value after I flip: 399

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

解决方法

使用异或:
SELECT value ^ 256

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

SELECT value ^ POWER(2,power)

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...