mysql模糊匹配多个值的两种方法实例
要求:实现mysql中对同个字段进行多个匹配值的模糊查询
先看数据表:
目标是在user表中,匹配出姓氏在family_info表中的记录。
方法一:将like作为连接条件
将查询表与需要匹配的多个值(可以是表或select子句结果)进行左连接,以字段使用like模糊匹配作为连接条件,再对连接结果进行非空过滤。
先看like模糊匹配作为连接条件的结果:
select u.*,fi.* from `user` u left join family_info fi on u.name like concat(fi.family_name, '%')
能看到,没有对应匹配值的数据在查询中,family_name字段结果是null,此时再把语句进行调整,将匹配后family_name为null值的数据进行过滤,得到所需要的查询语句:
select u.* from `user` u left join family_info fi on u.name like concat(fi.family_name, '%') where fi.family_name is not null
能得到姓名为“张”、“王”开头的记录。
方法二:正则表达式搭配group_concat函数
使用group_concat函数来生成任意字符串左匹配的正则表达式字符串:
select group_concat(concat('^',fi.family_name) SEPARATOR '|') from family_info fi
使用regexp操作符来使用正则表达式:
select * from user u where u.name regexp ( select group_concat(concat('^',fi.family_name) SEPARATOR '|') from family_info fi )
结果是查询出了姓名为“张”、“王”开头的记录。
示例表的表语句:
CREATE TABLE `user` ( `name` varchar(32) DEFAULT NULL COMMENT '姓名', `age` int(11) DEFAULT NULL COMMENT '年龄' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表' INSERT INTO `user` (name,age) VALUES ('张三',21), ('李四',22), ('王五',23), ('张六',24), ('李七',25), ('王八',26); CREATE TABLE `family_info` ( `family_name` varchar(32) DEFAULT NULL COMMENT '姓氏' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='姓氏表' INSERT INTO family_info (family_name) VALUES ('张'), ('王');
总结
到此这篇关于mysql模糊匹配多个值的文章就介绍到这了,更多相关mysql模糊匹配多个值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
mysql索引过长Specialed key was too long的解决方法
在创建要给表的时候遇到一个有意思的问题,提示Specified key was too long; max key length is 767 bytes,本文就来介绍一下解决方法,如果你也遇到此类问题,可以参考一下2021-11-11MySQL 5.7.14 net start mysql 服务无法启动-“NET HELPMSG 3534” 的奇怪问题
这篇文章主要介绍了MySQL 5.7.14 net start mysql 服务无法启动-“NET HELPMSG 3534” 的奇怪问题,需要的朋友可以参考下2016-12-12mysql忘记root密码的解决办法(针对不同mysql版本)
这篇文章主要介绍了mysql忘记root密码的解决办法(针对不同mysql版本),文章通过代码示例和图文结合的方式给大家讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下2024-06-06
最新评论