比较 MySQL 中的二进制值

发布于 2024-11-30 10:26:01 字数 285 浏览 1 评论 0原文

假设你有两个二进制值,

001011 
001111

如何获得 MySQL 中不同位数的数量?我尝试了

SELECT BIT_COUNT(BINARY  001011 ^ BINARY 001111)

This 返回 6,而我需要一个在此示例中返回 1 的解决方案。

Say you have two binary values

001011 
001111

How can you get the number of different bits in MySQL? I tried

SELECT BIT_COUNT(BINARY  001011 ^ BINARY 001111)

This returns 6, while I need a solution that returns 1 in this example.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

淡紫姑娘! 2024-12-07 10:26:01
SELECT BIT_COUNT( CONV( '001011', 2, 10 ) ^ CONV( '001111', 2, 10 ) )
SELECT BIT_COUNT( CONV( '001011', 2, 10 ) ^ CONV( '001111', 2, 10 ) )
梦与时光遇 2024-12-07 10:26:01
SELECT BIT_COUNT(b'001011' ^ b'001111');
SELECT BIT_COUNT(b'001011' ^ b'001111');
巷子口的你 2024-12-07 10:26:01

它将数字 1011 和 1111(以 10 为基数)转换为二进制并进行比较。如果你这样做了:

SELECT BIT_COUNT(11 ^ 15)

它会起作用。

It's converting the numbers 1011 and 1111 (base 10) to binary and doing the comparison. If you did:

SELECT BIT_COUNT(11 ^ 15)

It'd work.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文