问题描述
我想获取以“阅读”和“绘画”为兴趣的人的姓名。
解决方案给出的可能结果之一如下。
SELECT name
FROM people_interests
WHERE interests & 1 AND interests & 8
ORDER BY name
但是,我不明白为什么这个查询在这里起作用。有人能解释一下为什么会这样吗? &
运算符在这里做什么?
解决方法
这很奇怪。我怀疑其意图是向您介绍 MySQL 中的 set
数据类型。文档是 here。
这很奇怪的原因是列中的分号。集合通常使用逗号作为分隔符——这是记录在案的分隔符,我认为没有任何方法可以更改它们。
也就是说,通常不推荐使用套装,原因如下:
- 它们特定于 MySQL。
- 它们在集合中可以存储的值数量有限。
- 它们可能令人困惑,因为它们混淆了字符串、整数和位位置。
在某些特定情况下,它们可能很有用,但大多数数据库在没有它们的情况下也能做得很好。