共计 1185 个字符,预计需要花费 3 分钟才能阅读完成。
在工作中,经常会遇到一对多的关系,比如用户和爱好。
想要在 Mysql 中保存这种关系,一般有两种方式:
文章来源地址 https://www.toymoban.com/diary/sql/210.html
第一种是 建立 一张用户爱好 表 user_hobby(user_id, hobby_id),这样一条 user_id 就会 存在多条记录。
第二种方式,直接在用户表中 增加 hobby_ids 字段,将 hobby_id 拼接成用逗号分隔的字符串保存起来。
文章来源:https://www.toymoban.com/diary/sql/210.html
那么问题来了,如果采用第二种方式的话,查询的时候要如何处理呢?下面介绍几种常见的处理方式。
一、like
可能最新想到的是采用 like 的形式,如下:
select * from user where hobby_ids like '%1%';
这种方式是否可行呢?行,但是有适用范围,如果 hobby_id 在 10 以内,那么这么处理完全是可以的,但是一旦超过了 10,那 ’%1%’ 就会把 10,11, 这些带 1 的 id 全都匹配处理。
二、find_in_set
为了解决 like 存在的问题,还可以使用 mysql 提供的 find_in_set(str, strlist),sql 可以这样写:
select * from user where find_in_set('1', hobby_ids);
这样 mysql 就会把 hobby_ids 的值,按照逗号分隔的一个个元素去匹配。如果我们要匹配多个值要怎么办呢,比如查找喜欢 1 - 篮球或 2 - 足球的用户,可以
select * from user where find_in_set('1', hobby_ids) or find_in_set('2', hobby_ids);
如果匹配的值较多,我们可能要拼很长的 sql,那有没有稍微简短的方式呢,我们可以采用下面的方式。
三、regexp
regexp 是 mysql 提供的强大的正则匹配方式。上面的 sql 就可以改写成:
select * from user where hobby_ids regexp '(^|,)(1|2)(,|$)';
这里是完全采用字符串正则匹配的方式,(1|2)表示匹配 1 或者 2,(^|,)表示数字前面必须是字符串开头或者是一个逗号,(,|$)表示数字后面必须是逗号或者字符串的结尾。这样就可以完整匹配逗号分隔的元素了。
到此这篇关于 Mysql 逗号分隔的字段查询的文章就介绍到这了, 更多相关内容可以在右上角搜索或继续浏览下面的相关文章,希望大家以后多多支持 TOY 模板网!
原文地址:https://www.toymoban.com/diary/sql/210.html
如若转载,请注明出处:如若内容造成侵权 / 违法违规 / 事实不符,请联系站长进行投诉反馈,一经查实,立即删除!