mysql contains函数_多属性、多分类MySQL模式设计

面对数据同时属于多个分类的情况,本文介绍了使用bit数据类型来设计MySQL表结构,通过将分类转化为二进制并转为十进制存储,提高查询效率。在查询时,可以简单地通过where条件进行匹配。此外,还提到了JSON和SET数据类型的查询方法,但它们在索引效率上不如bit类型。
摘要由CSDN通过智能技术生成

155c9fe91e49e6c995953f416d7fc6af.png

一、导读
这是来自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&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值