如何通过按位运算符操作 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
| id | part | colours |
|----|--------|-------------|
| 1 | abc123 | Red,Blue |
| 2 | xyt788 | Black,Green |
解释
&
AND 按位运算符将比较两个二进制值中的两个值。
例如:
BitColor
是 3
= 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
的结果就可以得到值
我们有一个 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
| id | part | colours |
|----|--------|-------------|
| 1 | abc123 | Red,Blue |
| 2 | xyt788 | Black,Green |
解释
&
AND 按位运算符将比较两个二进制值中的两个值。
例如:
BitColor
是 3
= 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
的结果就可以得到值