多平台统一管理软件接口,如何实现多平台统一管理软件接口
861
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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~