mysql一个字段存储多数据的查询方式

    在开发中我们经常遇到类似给文章添加标签的问题,一般常规的存储方式是在文章表(content)中建一个标签字段(tags),在这个字段中存入类似 1,3,5,22这种的数字字符串。这样就会产生一个问题就是在前端我们经常需要根据标签来展示文章。

方法一

    而通常这种的查询我们喜欢采用like(此处先不考虑效率问题)。

    即:

select * from content where tags like "%2%";

    问题:显而易见的是我们这样是错误的,因为会把tags中存在22的记录也会查找出来。

    解决方法:没有什么好的办法,只能在insert时插入类似,1,11,3,23,2,(两边加分隔符)这种的字符串,再通过:

select * from content where tags like "%,2,%";

方法二

    其实根本不需要这么麻烦,因为这种常见的问题mysql官方就给出了解决方案,即函数find_ind_set。

    即:

select * from content where find_in_set(2,tags);

方法三

    还有一种方法就是采用全文搜索match against

    即:

select * from content  where match(tags) against('2' in boolean mode);

    注意:

        1.这种方法必须给字段tags添加全文索引;

        2.MySQL5.6之前innoDb不支持全文索引,需要改为myisam;

对比分析:

    既然有了三种方法,我们当然要比较一下优劣喽。

    我在本地用一个200w+的表来做的测试,发现总体上来说

    速度上:方法三 > 方法二 > 方法一,大概相差都是1/3左右。

    感想:这个函数的发现充分的展示了自己对mysql的生疏,一个程序员对数据库的深入了解是必不可少的,包括各种原生函数和各种索引的应用,往往使人事半功倍。

最后,欢迎大家对比测试,评论区见!

    

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值