MySQL 两个字段的like模糊匹配

普通情况

挑选出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;
    原文作者:一只小辣鸡
    原文地址: https://blog.csdn.net/weixin_41471128/article/details/84840331
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞