普通情况
挑选出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;