我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql模糊匹配多个值的两种方法实例

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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, '%')

mysql模糊匹配多个值的两种方法实例

能看到,没有对应匹配值的数据在查询中,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

mysql模糊匹配多个值的两种方法实例

能得到姓名为“张”、“王”开头的记录。

方法二:正则表达式搭配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模糊匹配多个值内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql模糊匹配多个值的两种方法实例

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql模糊匹配多个值的两种方法实例

目录要求:实现mysql中对同个字段进行多个匹配值的模糊查询方法一:将like作为连接条件方法二:正则表达式搭配group_concat函数总结要求:实现mysql中对同个字段进行多个匹配值的模糊查询先看数据表:目标是在user表中,匹配
2022-12-15

编程热搜

目录