vlambda博客
学习文章列表

【Mysql】实现多字段模糊查询

解决办法:

《MySQL权威指南》中CONCAT的使用方法,在书中的对CONCAT的描述是:

CONCAT(str1,str2,…)
返回值:由全体出入参数合并在一起而得到的字符串。只要输入的参数中有NULL值,就返回NULL。CONCAT允许只有一个输入参数的情况。

因此,MySQL单表多字段模糊查询可以通过下面这个SQL查询实现:

selec * from  table  where 1 and CONCAT(省,市,县,期,栋,单元,室) like '%查询的地址%';

但是这样有个问题,如果这几个字段中有值为NULL,则返回的也是NULL,那么这一条记录可能就会被错过,怎么处理呢,我这边使用的是IFNULL进行判断,则sql改为:

selec * from  table  where 1 and CONCAT(IFNULL(省),IFNULL(市),IFNULL(县),IFNULL(期),IFNULL(栋),IFNULL(单元),IFNULL(室)) like '%查询的地址%';