mysql查询FIND_IN_SET?REGEXP实践示例(mysql查询表结构语句)墙裂推荐

随心笔谈2年前发布 编辑
161 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



目录背景FIND_IN_SET实现REGEXP实现如何选择

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

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

<if test=”query.movieTypeId !=null”>
AND FIND_IN_SET(${query.movieTypeId}, movie_type_ids)
</if>

注意:FIND_IN_SET字符串之间不要有空格,空格可能导致查询失败!

<if test=”query.movieTypeId !=null”>
AND movie_type_ids REGEXP ‘[[:<:]]${query.movieTypeId}[[:>:]]’
</if>

一般来说, 比  的查询效率更高。这是因为  函数是一个 MySQL 内置函数,而  是一个正则表达式引擎,需要进行更多的计算。

如果你需要进行更为复杂的匹配操作,可以考虑使用 。 最大的优势在于可以进行高级的匹配操作,因此,在实际使用中需要根据具体情况来选择不同的匹配方式,以达到最优的查询效率。

以上就是mysql查询FIND_IN_SET REGEXP实践示例的详细内容,更多关于mysql查询的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:mysql查询过去24小时内每小时数据量的方法(精确到分钟)mysql 模糊查询 concat()的用法详解Mysql查询优化之IN子查询优化方法详解mysql中如何查询数据库中的表名MySQL自动为查询数据结果加序号

© 版权声明

相关文章