一、导读
这是来自B乎的一个问答。 当数据同时具备多个属性/分类时,改如何设计表结构和查询?
二、需求描述
我偶尔也会逛逛B乎,看到一些感兴趣的话题也会回复下。 有一次,看到这样的一个话题:
链接:https://www.zhihu.com/questio...
[mysql] 当数据同时属于多个分类时,该怎么查询?
分类cate字段为[1,2,3,4,5] ,假如要查询满足分类’2’和’5′ 的数据该怎么查询? 我尝试过用 cate like ‘%2%’ AND cate like ‘%5%’去查。 想问有没有更好的办法,我这样写数据少了还好,多了根本没法查,效率太低了。
恰好我以前做过类似的业务需求设计,所以就回复了这个问题。
三、模式设计思路
这个需求可以有几种不同的解决思路,我们分别展开说一下。
(一)用bit数据类型
大概思路如下:
1、物品属性列c1 用bit数据类型 来表示,也就是只有0、1两种取值
2、当物品属性具备某个分类属性时,其值为1,否则为0
3、假如共有5个分类,当物品拥有全部分类属性时,则其值为11111,若其不具备第3个分类属性,则其值为11011&