MyBatis if test 判断字符串相等不生效问题

 更新时间:2022年10月12日 11:15:30   作者:长安明月  
这篇文章主要介绍了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>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java 实现DES 加密解密的示例

    java 实现DES 加密解密的示例

    这篇文章主要介绍了java 实现DES 加密解密的示例代码,帮助大家更好的理解和使用Java进行加解密,感兴趣的朋友可以了解下
    2020-12-12
  • 使用BigDecimal进行精确运算(实现加减乘除运算)

    使用BigDecimal进行精确运算(实现加减乘除运算)

    这篇文章主要介绍了如何使用BigDecimal进行精确运算,最后提供了一个工具类,该工具类提供加,减,乘,除运算
    2013-11-11
  • 如何解决hibernate一对多注解懒加载失效问题

    如何解决hibernate一对多注解懒加载失效问题

    这篇文章主要介绍了解决hibernate一对多注解懒加载失效的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • springboot配置ssl后启动一直是端口被占用的解决

    springboot配置ssl后启动一直是端口被占用的解决

    这篇文章主要介绍了springboot配置ssl后启动一直是端口被占用的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Spring Cloud 的 Hystrix.功能及实践详解

    Spring Cloud 的 Hystrix.功能及实践详解

    这篇文章主要介绍了Spring Cloud 的 Hystrix.功能及实践详解,Hystrix 具备服务降级、服务熔断、线程和信号隔离、请求缓存、请求合并以及服务监控等强大功能,需要的朋友可以参考下
    2019-07-07
  • Map 使用 Lambda 的 forEach 实现跳出循环操作

    Map 使用 Lambda 的 forEach 实现跳出循环操作

    这篇文章主要介绍了Map 使用 Lambda 的 forEach 实现跳出循环操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • 百度Java面试题 前200页精选(下)

    百度Java面试题 前200页精选(下)

    这篇文章主要为大家分享了Java面试资源下篇,百度“Java面试题”前200页都在这里了,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • mysql数据库忘记密码时如何修改

    mysql数据库忘记密码时如何修改

    本文主要介绍了mysql数据库忘记密码时如何修改的步骤方法,具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • Java中自定义注解类及使用实例解析

    Java中自定义注解类及使用实例解析

    这篇文章主要介绍了Java中自定义注解类并使用过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • Java实现的校验银行卡功能示例

    Java实现的校验银行卡功能示例

    这篇文章主要介绍了Java实现的校验银行卡功能,结合完整实例形式分析了java针对银行卡类型、归属地等信息的判断、读取相关操作技巧,需要的朋友可以参考下
    2018-06-06

最新评论