Mybatis-plus3.5.1在xml中用test aColumn 不等于** AND aColumn 不等于** 引发的问题

Mybatis Mybatis-plus3.5.1在xml中用test aColumn !=** AND aColumn !=** 引发的问题

问题产生原因:

最近一段时间一直使用的是 Mybatis-plus, 对于xml中sql的编写能力实际上是缺少了一定的认知的,那么按照从前的习惯去编写xml中的sql就会默认觉得没问题! BUT!!!! 真的产生了问题,而且还确实应该记录一下这个神奇的场景

复现场景

其实场景很简单,就是对于状态值的处理,前端和后端沟通后的结果为:如果查询全部,需要向后端接口中传递一个 status为 0 的数据,用于标准化,(前后端对接口的规范,应该是有一条,status向后端传值不能传null 这种规定)那么后端就要在代码中处理该部分逻辑!

解决方案

对代码最简单的改变莫过于,在**Mapper.xml中 的 if 标签内 加上 if(test = “status !=0 and != null”) 这种判断逻辑以解决问题,但也不知道为什么脑子抽抽了一下,将and 变成了 AND 然后就出现了问题!!虽然以前也没写过AND 但这种情况我认知中框架好像都帮助我们进行大小写转换,然后再进行判断这一类的。 所以啊,就是简单的改变了一下AND的 大小写, 就解决了问题。但!这种场景确实很少见。能写出这种bug也很少见 哈哈。

最终: if(test = “status !=0 AND != null”) 改变成 if(test = “status !=0 and != null”)

结尾:如果有什么其他更加解耦的解决方案,请各位大佬多多指点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值