Mybatis mysql模糊查询方式(CONCAT多个字段)及bug

网友投稿 823 2022-09-02


Mybatis mysql模糊查询方式(CONCAT多个字段)及bug

目录Mybatis mysql模糊查询及bug解决方案:一解决方案:二mybatis多个字段如何模糊查询一个值

Mybatis mysql模糊查询及bug

先看下如下xml

SELECT

t.id,

t.mobile,

t.account_name

FROM

t_account t

WHERE

1=1

and CONCAT(t.id,t.mobile,t.account_name) like CONCAT('%',#{keyVmpYcHfVDWord},'%')

正常来说这样写没问题的,但是如果你CONCAT的字段中有一个字段为null时,那这条数据将查询不到,说白了,只要有一个字段为null,就查不到数据了。

先看下以下数据。

从上图可以发现,id为7的mobile为null的,接下来咱们测试下结果。

根据account_name模糊查询:查询柳岩是能查到数据的,如下图

查询张三是查询不到数据的,如下图

根据Id查id为7的也是查不到的,如下图

结论:CONCAT的字段中有任意一个字段为null时,那这条数据将查询不到

解决方案:一

改成用or连接

SELECT

t.id,

t.mobile,

t.account_name

FROM

t_account t

WHERE

1=1

and CONCAT(t.id) like CONCAT('%',#{keyWord},'%')

or CONCAT(t.mobile) like CONCAT('%',#{keyWord},'%')

or CONCAT(t.account_name) like CONCAT('%',#{keyWord},'%')

看下运行结果:查到张三这条数据了

VmpYcHfVD

解决方案:二

判null处理

SELECT

t.id,

t.mobile,

t.account_name

FROM

t_account t

WHERE

1=1

and CONCAT( IFNULL(t.id,''),IFNULL(t.mobile,''),IFNULL(t.account_name,'') ) like CONCAT('%',#{keyWord},'%')

mybatis多个字段如何模糊查询一个值

使用oracle concat 函数拼接字符 再进行like 操作

CONCAT(CONCAT(CONCAT(CONCAT(venderDesc,purcher),demandOrg),contactInfo),materialDesc) like#{searchContent}

注:venderDesc,purcher,demandOrg,contactInfo,materialDesc为表的字段,想要拼接哪个字段就拼哪个字段


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Django学习笔记之Django中间件(django中间件的五个方法)
下一篇:Django学习笔记之Cookie、Session和自定义分页(django cookie和session)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~