Mysql 逗号分隔的字段查询

2,363次阅读
没有评论

共计 1185 个字符,预计需要花费 3 分钟才能阅读完成。

在工作中,经常会遇到一对多的关系,比如用户和爱好。

想要在 Mysql 中保存这种关系,一般有两种方式:

文章来源地址 https://www.toymoban.com/diary/sql/210.html

第一种是 建立 一张用户爱好  user_hobby(user_id, hobby_id),这样一条 user_id 就会 存在多条记录

第二种方式,直接在用户表中 增加 hobby_ids 字段,将 hobby_id 拼接成用逗号分隔的字符串保存起来。

那么问题来了,如果采用第二种方式的话,查询的时候要如何处理呢?下面介绍几种常见的处理方式。

一、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

如若转载,请注明出处:如若内容造成侵权 / 违法违规 / 事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于1970-01-01发表,共计1185字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)