在开发中我们经常遇到类似给文章添加标签的问题,一般常规的存储方式是在文章表(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的生疏,一个程序员对数据库的深入了解是必不可少的,包括各种原生函数和各种索引的应用,往往使人事半功倍。
最后,欢迎大家对比测试,评论区见!