MySQL 两个字段的like模糊匹配

本文详细介绍了如何在SQL查询中使用模糊匹配,特别是针对MySQL数据库。通过示例展示了正确的语法,如使用CONCAT函数进行模糊匹配,以及如何将其应用于UPDATE语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

普通情况

挑选出tb1表的字段a中包含关键字’abc’的语法没我们可以这样写:

SELECT * FROM tb1 JOIN tb2 ON tb1.a=tb2.a
WHERE tb1.b LIKE '%a%'
问题

但是要模糊匹配一个字段呢?我试着这样写了一下:

SELECT * FROM tb1 JOIN tb2 ON tb1.a=tb2.a
WHERE tb1.b LIKE tb2.b
set xx=xx

上面那样写like模糊匹配只能匹配到tb1.a=tb2.b的结果,并不正确,搜索,从网上找到答案:

SELECT * FROM tb1 JOIN tb2 ON tb1.a=tb2.a
WHERE tb1.b LIKE '%'+tb2.b+'%'

MySQL执行错误,估计是其他数据库可以这样写,但是不适用于MySQL。
怎么办呢,网上搜不到其他答案了。

解决方案

试试concat?

SELECT * FROM tb1 JOIN tb2 ON tb1.a=tb2.a
WHERE tb1.b LIKE CONCAT('%',tb2.b,'%')

成功了!
好的解决,完美。

如果你想写更新语句,一样适用:

update tb1 join tb2 on tb1.a like concat('%',tb2.a,'%')
set tb1.xx=tb2.xx
where xxx;
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值