我的数据库中有一个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)
原文地址:https://www.jb51.cc/mssql/83437.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。