网络编程
位置:首页>> 网络编程>> 数据库>> mysql模糊匹配多个值的两种方法实例

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

作者:科学鸿  发布时间:2024-01-27 10:12:06 

标签:mysql,模糊匹配,多个值

要求:实现mysql中对同个字段进行多个匹配值的模糊查询

先看数据表:

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

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

使用regexp操作符来使用正则表达式:

select * from user u where u.name regexp
( select group_concat(concat('^',fi.family_name) SEPARATOR '|')  from family_info fi )

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

结果是查询出了姓名为“张”、“王”开头的记录。

示例表的表语句:

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

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com