这篇文章主要为大家介绍了mysql查询FIND_IN_SET REGEXP实践示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
背景
数据库存在一个字段,里面的数据是用逗号隔开存储的,比如某人的爱好、喜欢的电影类型等场景
现在前台需要根据具体的id查询相应的结果,比如查询某个类型电影有哪些人喜欢
FIND_IN_SET实现
<if test="query.movieTypeId != null">
AND FIND_IN_SET(${query.movieTypeId}, movie_type_ids)
</if>
注意:FIND_IN_SET字符串之间不要有空格,空格可能导致查询失败!
REGEXP实现
<if test="query.movieTypeId != null">
AND movie_type_ids REGEXP '[[:<:]]${query.movieTypeId}[[:>:]]'
</if>
如何选择
一般来说,FIND_IN_SET()
比 REGEXP
的查询效率更高。这是因为 FIND_IN_SET()
函数是一个 MySQL 内置函数,而 REGEXP
是一个正则表达式引擎,需要进行更多的计算。
如果你需要进行更为复杂的匹配操作,可以考虑使用 REGEXP
。REGEXP
最大的优势在于可以进行高级的匹配操作,因此,在实际使用中需要根据具体情况来选择不同的匹配方式,以达到最优的查询效率。
以上就是mysql查询FIND_IN_SET REGEXP实践示例的详细内容,更多关于mysql查询的资料请关注编程学习网其它相关文章!
本文标题为:mysql查询FIND_IN_SET REGEXP实践示例


基础教程推荐
- Java程序员从笨鸟到菜鸟(五十三) 分布式之 Redis 2023-09-11
- Mariadb数据库主从复制同步配置过程实例 2023-07-25
- Windows10系统中Oracle完全卸载正确步骤 2023-07-24
- Python常见库matplotlib学习笔记之画图中各个模块的含义及修改方法 2023-07-27
- redis乐观锁与悲观锁的实战 2023-07-13
- redis 数据库 2023-09-13
- oracle数据库排序后如何获取第一条数据 2023-07-24
- oracle19c卸载教程的超详细教程 2023-07-23
- SQL Server如何设置用户只能访问特定数据库和访问特定表或视图 2023-07-29
- Python安装第三方库的方法(pip/conda、easy_install、setup.py) 2023-07-28