mysql regexp匹配多个字符串

项目场景:

数据结构

其中nameArr存储的是名字集合,现在的需求是传入"aaa","fff",需要把包含这两个name的数据都查出来。


解决方案:

可以使用REGEXP来匹配包含多个特定ID的字符串。使用以下正则表达式:

sql 复制代码
select * from test
where nameArr regexp '"aaa"|"fff"'

使用mybatis实现

mapper

java 复制代码
/**
 * 正则匹配多个id字符串
 */
List<TestEntity> list(@Param("ids") List<String> ids);

xml

XML 复制代码
<select id="list" resultType="com.test.TestEntity">
	select * from test
	<if test="ids != null and ids.size()>0">
		and nameArr regexp concat('"',
		concat_ws('"|"',
		<foreach collection="ids" item="item" separator=",">
			#{item}
		</foreach>
		),'"')
	</if>
</select>

解析一下这个sql

ids这个集合会循环逗号拼接,打印sql

sql 复制代码
select * from test
where nameArr regexp concat('"',concat_ws('"|"','aaa','fff'),'"')

最终的sql

sql 复制代码
select * from test
where nameArr regexp '"aaa"|"fff"'
相关推荐
阿苟16 分钟前
数据库重点难点
redis·后端·mysql
环流_21 分钟前
Redis:epoll和IO多路复用
java·redis·mybatis
欢璃23 分钟前
表白墙案例
java·开发语言·jvm·spring boot·spring·maven·mybatis
敖正炀24 分钟前
MySQL 线上问题实战演练:复合故障排查与系统设计
mysql
醇氧31 分钟前
CentOS 7安装 mysql-8.0.27-1.el7.x86_64.rpm 安装包
android·mysql·centos
敖正炀43 分钟前
慢查询与性能诊断:PMM、pt-query-digest 与 sys schema
mysql
敖正炀1 小时前
主从复制与 GTID:半同步、并行复制
mysql
敖正炀1 小时前
InnoDB 引擎深度:B+Tree、页与行格式
mysql
敖正炀1 小时前
事务与 MVCC:Undo Log、ReadView 与隔离级别
mysql
老码观察1 小时前
K8s集群断电后MySQL恢复实录:从InnoDB崩溃到数据完整迁移
mysql·adb·kubernetes