[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]mybatis为什么不拼接id=0的条件。

上一篇:[备忘]netty不发送数据包的调查
下一篇:[备忘]Log4j的1.x版本,大并发会导致线程BLOCKED

添加日期:2021/7/20 18:54:09 快速返回   返回列表 阅读930次
<if test="id != null and id != ''"> and id=#{id}</if>
如果id=0,则这个条件不会拼接。
不是0,则没有问题。
----------------------------------------
mybatis会比较表达式:
(1)id!=null,这个没毛病,是true
(2)id!='',id是0,它和空串怎么比较呢?
debug了半天,有这样的代码:


protected Object getValueBody(OgnlContext context, Object source) throws OgnlException {
        Object v1 = super.children[0].getValue(context, source);
        Object v2 = super.children[1].getValue(context, source);
        return OgnlOps.equal(v1, v2) ? Boolean.FALSE : Boolean.TRUE;
    }


OgnlOps.equal()里面比较了半天,最后把两边都转成数字进行比较了。
空串变成了0,所以0!='',是false,所以整个表达式是false,所以条件不拼接。
----------------------------------------
如果id不是0,比如是88,那么88!=0,是true,所以条件拼接。
----------------------------------------
解决办法:只留id!=null即可。
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved