mysql如何匹配数组字段中的某一个具体值

 更新时间:2024年11月06日 09:13:54   作者:樘棣寂寂  
在数据库操作中,有时需要查询数组字段中包含特定值的数据,传统like查询可能会带来错误结果,如查询包含数字1的数组可能错误返回包含数字10的结果,为此,可以使用MySQL的FIND_IN_SET函数或REGEXP正则表达式进行精确匹配,FIND_IN_SET适用于匹配单个固定值

应用背景

业务表中的某个字段存储的值为数组,例如 1,2,3 。

现在需要查询其中一个值是数组里面的对应的一个值,该如何匹配。

就比如subject这个字段为一个数组,现在需要查询subject包含1的学生。

使用模糊查询的问题

因为subject里面存的不是具体的一个值,所以使用=显然是不行的,这个时候大家首先会想到like的模糊查询,我们一起来看看效果

SELECT
	* 
FROM
	`stu_c` 
WHERE
	subject LIKE '%1%'

执行结果

可以看到将张三跟王五都查出来了,这显然跟我们的需求不符,需求是只包含1的,应该只查出来张三这条数据才对。

解决方案一

使用mysql中的FIND_IN_SET(str,fieldName)函数,str是要查询的字符串,fieldName是字段名,参数以“,”分隔,例如1,2,3

匹配单个(只包含1)sql语句如下

SELECT * FROM stu_c WHERE FIND_IN_SET('1', subject) > 0 

匹配单个(只包含1)执行结果

查出了subject包含1的学生信息

匹配多个(包含1跟3)sql语句如下

SELECT * FROM stu_c
WHERE FIND_IN_SET('1', subject) > 0 OR FIND_IN_SET('3', subject) > 0;

匹配多个(包含1跟3)执行结果

查出了subject包含1跟3的学生信息

解决方案二

使用REGEXP正则表达式匹配,REGEXP语法更加强大,功能更全,可以根据不同的需求选择不同的用法,本文主要讲查询包含这个字符的数据

匹配单个(只包含1)sql语句如下

SELECT
	* 
FROM
	`stu_c` 
WHERE
	CONCAT ( ',', subject, ',' ) REGEXP ',(1),'

匹配单个(只包含1)执行结果

查出了subject包含1的学生信息

匹配多个(包含1跟3)sql语句如下

SELECT
	* 
FROM
	`stu_c` 
WHERE
	CONCAT ( ',', subject, ',' ) REGEXP ',(1|3),'

匹配多个(包含1跟3)执行结果

查出了subject包含1跟3的学生信息

总结

两种方式都能解决匹配数组字段中某一个具体值的问题,但是也有差异,有各自的优缺点,例如FIND_IN_SET(str,fieldName)函数,如果前端页面是多选项,也就是需要匹配满足多个值的情况,就需要使用or拼接sql,但是REGEXP只需要把参数转换为我们需要的格式(',(1|3),')即可。

如果项目需求只需匹配一个值,FIND_IN_SET函数直接在xml中使用就行,REGEXP仍需要将单个参数转换为特定的格式(,(1),)。

综上所述,单个值匹配建议用FIND_IN_SET函数,多个值匹配建议用REGEXP正则表达式。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql 模糊查询 concat()的用法详解

    mysql 模糊查询 concat()的用法详解

    大家都知道concat()函数,是用来连接字符串,今天通过本文给大家介绍mysql 模糊查询 concat()及concat的用法,感兴趣的朋友跟随小编一起看看吧
    2023-02-02
  • mysql 复制行数据命令经验分享(Mysql 复制一条数据)

    mysql 复制行数据命令经验分享(Mysql 复制一条数据)

    有时候表里有一行已经添加好的数据,想要多复制几百条用来测试比如要分页测试等,需要多条数据,但是有时候数据表字段太多了,有几十个,一个一个手写那是不可能的
    2023-09-09
  • mysql insert if not exists防止插入重复记录的方法

    mysql insert if not exists防止插入重复记录的方法

    在 MySQL 中,插入(insert)一条记录很简单,但是一些特殊应用,在插入记录前,需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作,本文介绍的就是这个问题的解决方案。
    2011-04-04
  • 出现错误mysql Table ''performance_schema...解决办法

    出现错误mysql Table ''performance_schema...解决办法

    这篇文章主要介绍了解决出现错误mysql Table 'performance_schema.session_variables' doesn't exist的相关资料,需要的朋友可以参考下
    2017-04-04
  • 本地windows安装两个mysql服务器,配置主从同步

    本地windows安装两个mysql服务器,配置主从同步

    大型网站为了缓解大量的并发访问,除了在网站实现分布式负载均衡,还会搭建服务器mysql集群技术,来分担主数据库的压力。在本地电脑能实现这样的技术吗,本地windows安装两个mysql服务器,配置主从同步也是可以实现的,快来跟着教程测试一下吧。
    2022-12-12
  • 值得收藏的mysql常用命令集锦

    值得收藏的mysql常用命令集锦

    这篇文章主要为大家整理了mysql常用命令汇总,连接Mysql、修改mysql密码、数据库的创建删除等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • SQL实现LeetCode(184.系里最高薪水)

    SQL实现LeetCode(184.系里最高薪水)

    这篇文章主要介绍了SQL实现LeetCode(184.系里最高薪水),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 关于SQL Update的四种常见写法

    关于SQL Update的四种常见写法

    这篇文章主要介绍了关于SQL Update的四种常见写法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • M1芯片安装mysql8.0数据库的实现步骤(图文)

    M1芯片安装mysql8.0数据库的实现步骤(图文)

    这篇文章主要介绍了M1芯片安装mysql8.0数据库的实现实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • MySQL学习之索引及优化

    MySQL学习之索引及优化

    这篇文章主要介绍MySQL的索引及优化,索引是帮助MySQL进行高效查询的一种数据结构。好比一本书的目录,能加快查询的速度,想进一步了解的小伙伴可以详细阅读本文
    2023-03-03

最新评论