开发者

mysql查询FIND_IN_SET REGEXP实践示例

开发者 https://www.devze.com 2023-05-10 09:00 出处:网络 作者: data_too_long
目录背景FIND_IN_SET实现REGEXP实现如何选择背景 数据库存在一个字段,里面的数据是用逗号隔开存储的,比如某人的爱好、喜欢的电影类型等场景
目录
  • 背景
  • FIND_IN_SET实现
  • REGEXP实现
  • 如何选择

背景

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

mysql查询FIND_IN_SET REGEXP实践示例

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

FIND_IN_SET实现

<if test="qu开发者_SQLiteery.movieTypeId != null">
   AND FIND_IN_SET(${query.movieTypeId}, movie_type_ids)
</if>

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

REGEXP实现

<if test="query.movieTypeId !=lrrwUpF null">
   AND movie_type_ids REGEXP '[[:&lt;:]]${query.movieTypeId}[[:>:]]'
<javascript;/if>

如何选择

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

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

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

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号