翼度科技»论坛 编程开发 mysql 查看内容

mysql查询FIND_IN_SET REGEXP实践示例

6

主题

6

帖子

18

积分

新手上路

Rank: 1

积分
18
背景

数据库存在一个字段,里面的数据是用逗号隔开存储的,比如某人的爱好、喜欢的电影类型等场景

现在前台需要根据具体的id查询相应的结果,比如查询某个类型电影有哪些人喜欢

FIND_IN_SET实现
  1. <if test="query.movieTypeId != null">
  2.    AND FIND_IN_SET(${query.movieTypeId}, movie_type_ids)
  3. </if>
复制代码
注意:FIND_IN_SET字符串之间不要有空格,空格可能导致查询失败!

REGEXP实现
  1. <if test="query.movieTypeId != null">
  2.    AND movie_type_ids REGEXP '[[:&lt;:]]${query.movieTypeId}[[:>:]]'
  3. </if>
复制代码
如何选择

一般来说,
  1. FIND_IN_SET()
复制代码
  1. REGEXP
复制代码
的查询效率更高。这是因为
  1. FIND_IN_SET()
复制代码
函数是一个 MySQL 内置函数,而
  1. REGEXP
复制代码
是一个正则表达式引擎,需要进行更多的计算。
如果你需要进行更为复杂的匹配操作,可以考虑使用
  1. REGEXP
复制代码
  1. REGEXP
复制代码
最大的优势在于可以进行高级的匹配操作,因此,在实际使用中需要根据具体情况来选择不同的匹配方式,以达到最优的查询效率。
以上就是mysql查询FIND_IN_SET REGEXP实践示例的详细内容,更多关于mysql查询的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/article/283708.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具