mysql模糊匹配多个值的两种方法实例
作者:科学鸿 时间:2024-01-27 10:12:06
要求:实现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
('张'),
('王');
来源:https://blog.csdn.net/qq_38066290/article/details/124100742
标签:mysql,模糊匹配,多个值
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
C#动态创建Access数据库及密码的方法
2024-01-17 21:37:21
![](https://img.aspxhome.com/file/2023/0/92980_0s.jpg)
解决python super()调用多重继承函数的问题
2022-09-28 07:50:44
jquery常用的表单操作很全很详细
2011-09-01 19:21:11
使用python turtle画高达
2021-11-05 20:47:48
![](https://img.aspxhome.com/file/2023/2/84082_0s.jpg)
python多任务之协程的使用详解
2023-12-29 16:38:23
详细解读Python中解析XML数据的方法
2021-08-18 11:56:24
详解Python中的相对导入和绝对导入
2023-02-05 01:10:36
自学MySql内置函数知识点总结
2024-01-23 11:19:04
Python将列表中的元素转化为数字并排序的示例
2023-07-06 11:16:11
Python办公自动化之Excel(中)
2023-03-07 05:48:15
YOLOv5车牌识别实战教程(六)性能优化与部署
2022-04-26 12:40:54
![](https://img.aspxhome.com/file/2023/3/69573_0s.png)
Python编写memcached启动脚本代码实例
2023-02-13 19:59:51
对setInterval在火狐和chrome切换标签产生奇怪的效果之探索,与解决方案!
2024-04-28 09:43:23
Vue自定义指令中无法获取this的问题及解决
2024-05-29 22:46:46
![](https://img.aspxhome.com/file/2023/3/123003_0s.png)
如何从IP获知其所在地?
2009-11-15 19:54:00
python 实现将txt文件多行合并为一行并将中间的空格去掉方法
2021-12-16 12:17:09
python调用百度语音识别api
2023-02-13 10:23:48
![](https://img.aspxhome.com/file/2023/4/133414_0s.jpg)
详解Python各大聊天系统的屏蔽脏话功能原理
2021-02-23 13:53:44
![](https://img.aspxhome.com/file/2023/7/95307_0s.png)
使用python删除nginx缓存文件示例(python文件操作)
2021-10-16 03:41:32
OpenCV视频流Python多线程处理方法详细分析
2022-02-14 20:29:45