【容易坑】mybatis中使用if标签比较两个字符串是否相等

资料都来自于网络,这里只是记录一下,仅供参考

现象

上传参数确实为3,但是到了sql中还是2,很纳闷,确定不是上送参数的问题

问题解决

问题的关键点就在于为啥偏偏是2身上,仔细看一下sql语句,这个activityType还是和2产生过联系的。

这是一个简单的条件判断,并决定排序字段的语句,但是中间却使用了等号作为判断条件,显然这儿是不成立的,大抵已经找到原因了。

activityType就是在这个if判断语句中,被赋值为2的,即使在Mybatis的初始绑定值为3,那这么说的话,activityType不为null时,它的值会一直为2。

继续往下面想,这个if语句的执行顺序,应该是在执行SQL查询之前,那可以推断的是,Mybatis在执行SQL时,首先是先将所有的标签转化组装为SQL,然后在执行SQL语句。所以这里就已经被赋错了值。

解决办法也特别简单,就是再加一个=就可以了,标准的判断语句而已。

补充 :mybatis的映射文件中,使用的是ognl表达式,所以在字符串进行判等的时候,可使用以下两种方法

<if test="sex=='Y'.toString()">

或者

<if test = 'sex== "Y"'>

唯独不能使用

<if test="sex=='Y'">

因为mybatis会把'Y'解析为字符,java是强类型语言,所以不能这样写。

其他方案

方法一:

复制代码
<if test="delFlag == '2'.toString()">
    a.del_flag = #{delFlag}
</if>

方法二:

复制代码
<if test=' delFlag == "2" '>
    a.del_flag = #{delFlag}
</if>

注意test 后面跟的是双引号( " " )还是单引号( ' ' )

ps:用equals()亲测也可以

方法三:

复制代码
<if test=' delFlag.equals("2") '>
    a.del_flag = #{delFlag}
</if>

注意:使用如下方式是错的

复制代码
1 <if test=" delFlag == '2' ">
2     a.del_flag = #{delFlag}
3 </if>

使用上面示例中 "delFlag =='2' " , Mybatis会将 "2" 解析为字符(java 强类型语言, '2' char 类型 ),而非字符串,不能做到判断的效果。 要在Mybatis中判断字符串是否相等,请使用 方法一 或 方法二。

参考:

Mybatis踩坑记录------if从句中的赋值乌龙_mybatise中if判断语句可以有两个变量不-CSDN博客

mybatis xml文件中用 if 标签判断字符串是否相等 - r1-12king - 博客园

相关推荐
Boilermaker19926 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维7 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_997 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子7 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34167 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
恋爱绝缘体18 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wszy18098 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
wszy18099 小时前
顶部标题栏的设计与实现:让用户知道自己在哪
java·python·react native·harmonyos
程序员小假9 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
资生算法程序员_畅想家_剑魔9 小时前
Kotlin常见技术分享-02-相对于Java 的核心优势-协程
java·开发语言·kotlin