如何通过按位运算符操作 SQL JOIN?

How can I do SQL JOIN by bitwise operator manipulation?

我们有一个 SQL Server 2014 数据库,其中包含两个 table:

在部件 table 中,BitColours 是引用颜色 table 中的行的按位数字。

我们被要求生成这样的查询:

我以前从未做过这种类型的操作,因此非常感谢任何指导。

谢谢

您可以尝试通过AND按位运算符(&)连接两个表。

查询 1:

SELECT
    p.id,
    p.part,
     STUFF((
          SELECT ',' + c.Colour
          FROM colours c
          WHERE c.BitId & p.BitColurs > 0
          FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 1, '') colours
FROM parts p 

Results:

| id |   part |     colours |
|----|--------|-------------|
|  1 | abc123 |    Red,Blue |
|  2 | xyt788 | Black,Green |

解释

& AND 按位运算符将比较两个二进制值中的两个值。

例如:

BitColor3 = 00011

这是一个示例,我忽略了二进制 16 之后的许多零。

红色

    00011
---------------------
(&) 00001 = Red (1)
---------------------
    00001 = (1)

蓝色

    00011
---------------------
(&) 00010 = Blue (2)
---------------------
    00010 = (2)

黑色

    00011
---------------------
(&) 00100 = Black (4)
---------------------
    00000 = (0)

绿色

    00011
---------------------
(&) 01000 = Green (8)
---------------------
    00000 = (0)

所以我们可以用BitId&BitColurs进行二进制计算,得到更大0的结果就可以得到值