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”)