MyBatis if test 判断字符串相等不生效问题
作者:长安明月 发布时间:2021-10-11 22:42:01
标签:MyBatis,if,test,判断,字符串
MyBatis if test 判断字符串相等不生效
采用 MyBatis 框架操作 MySQL 数据库时,判断传入的字符串 priceFlag 值为"0"时,按照 price 属性降序排列,如下 xml 语句未生效:
<if test="priceFlag != null and priceFlag == '0'">
ORDER BY price DESC
</if>
原因分析
MyBatis 是使用 OGNL 表达式来进行解析的,在 OGNL 表达式中,'0’会被解析成字符,因为 java 是强类型的,char 和 String 不等,所以 if 标签中的 SQL 不会被解析。
解决方法
解决这个问题,可以把 if test 判断语句修改成如下几种方式中的任何一种:
<if test='"0" == priceFlag'>
或者
<if test='"0".equals(priceFlag)'>
或者
<if test="'0'.toString() == priceFlag">
修改完成后,SQL 语句就可以被解析了。
MyBatis if test 判断字符串相等的坑
自己开发的系统,客户反映有问题,本着不想改java代码,想想从数据库入手,加一些判断条件就想到了if test判断等于某个字符串执行另一个sql语句的原则,没想到想当然了,使用 if test=“sex==‘m’”直接报错,看了下网上果然大家都有遇到这样的问题,解决方式如下:
1. if 判断字符串
错误写法:if test="status == 'Y'"特别是数字字符的时候。。。。
结果:抛异常NumberFormatException异常!提示内容非常少,看不出问题在哪里!
正确写法:if test='status == "y" '
还可以这样写:if test="status == 'y'.toString()"
2. if嵌套
<if test="@com.qbao.tickets.common.util.MybatisUtils@isNotEmpty(firstLetter)">
<if test="firstLetter=='-1'.toString()">
and FIRST_LETTER is null or FIRST_LETTER =''
</if>
<if test="firstLetter!='-1'.toString()">
and FIRST_LETTER = #{firstLetter, jdbcType=VARCHAR}
</if>
</if>
来源:https://blog.csdn.net/piaoranyuji/article/details/108280023


猜你喜欢
- object对象中的 public boolean equals(Object obj),对于任何非空引用值 x 和 y,当且仅当 x 和
- 多说无益,贴代码:/** * 校验银行卡卡号 * * @param cardId &nbs
- IDEA快速创建getter和setter方法找到generate我的是Mac,右击鼠标就可以打开,相信windows也不难。选择gette
- “反射”其实就是利用程序集的元数据信息。 反射可以有很多方法,编写程序时请先导入 System.Reflection 命名空间。1、假设你要
- ServletWebServerApplicationContext实现了父类AbstractApplicationContext的onRe
- Jackson 日期格式化技巧使用 Spring Boot 时,需要使用 Jackson 处理一些 Java Time API 类型的 JS
- 实践过程效果代码public partial class Form1 : Form {
- 1,IDEA中Lombok作用数据库: 库 表 字段 对应的值 user表(id,name,age)实体对象pojo: 用来封装数据库中的数
- 一、 lib文件的简介.lib是一种文件后缀,是Windows操作系统的库文件,有静态lib和动态lib之分:1)、静态lib文件
- lombok插件使用引入依赖,在项目中使用Lombok可以减少很多重复代码的书写。比如说getter/setter/toString等方法的
- 实现方式和继承方式有什么区别呢?*区别:*继承Thread:线程代码存放在Thread子类run方法中*实现Runnable:线程代码存放在
- ExpandoObject:表示一个对象,该对象包含可在运行时动态添加和移除的成员。 dynamic dynEO = new Expando
- 一:CountdownEvent这种采用信号状态的同步基元非常适合在动态的fork,join的场景,它采用“信号计数&a
- 本文实例为大家分享了Android实现比赛时间闪动效果的具体代码,供大家参考,具体内容如下效果代码上代码public class Twink
- 1.需求背景需要实现一个动态加载但不显示出来的视图,且该视图上有个动态生成的二维码,最后用其去生成一张快照(也就是图片)。(常见这种情况是来
- 效果图如下: Recyclerview 实现多选,单选,全选,反选,批量删除的步骤1.在Recyclerview布局中
- 本文实例讲述了C#实现去除Strings中空格的方法,分享给大家供大家参考。具体实现方法如下:一般来说,你或许知道你能使用String.Tr
- 树概念及结构树是一种 非线性 的数据结构,它是由 n ( n>=0 )个有限结点组成一个具有层次关系的集合把它叫做树是因 为它看起来像
- asp.net页面中如何获取Excel表的内容,具体内容介绍如下所示:首先引用组件和命名空间using Microsoft.Office.I
- 一、简介   Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布