首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >mybatis的if test 字符串的坑

mybatis的if test 字符串的坑

作者头像
分母为零
发布2019-08-06 11:03:45
发布2019-08-06 11:03:45
2.8K00
代码可运行
举报
文章被收录于专栏:分母为零分母为零
运行总次数:0
代码可运行

mybatis的if test 字符串的坑

问题

代码语言:javascript
代码运行次数:0
运行
复制
<if test="type=='y'">  
    and status = 1   
</if>

当传入的type的值为1的时候,if判断内的sql也不会执行。

原因

mybatis是使用的OGNL表达式来进行解析的,在OGNL的表达式中,'y'会被解析成字符,因为java是强类型的,char 和 一个string 会导致不等。所以if标签中的sql不会被解析。

解决办法

只需要把代码修改成:(内双外单)

代码语言:javascript
代码运行次数:0
运行
复制
<if test='type=="y"'>  
    and status = 1   
</if>  

或者 也可以把代码修改 'y'.toString()

代码语言:javascript
代码运行次数:0
运行
复制
<if test="type == 'y'.toString()">  
    and status = 1   
</if>  

参考链接:https://blog.csdn.net/xl19961223/article/details/81362696

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 分母为零 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • mybatis的if test 字符串的坑
    • 问题
    • 原因
    • 解决办法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档