mybatis中一个逗号引发的血案

在做一个项目的过程中,发现一个问题。

mybatis的update语句中的<if test>...(知道是啥就好)

如果test的结果是失败的,那么后面的语句是不会加进去的!相当于在生成SQL查询语句时,这条语句是不存在的。

这就意味着,如果你有多个update,一旦你漏写了逗号,并且test失败,那么并不会报错!这就埋下了一个大坑,这可让我好找啊,一个逗号就那么一丢丢大小,找的眼睛都要烂掉了。

下面放代码。

            <if test="userInfo.userSex!=null">user_sex =
                #{userInfo.userSex}          ------------------(这里没有逗号,在userSex为空的时候,可以正常设置userYears)
            </if>
            <if test="userInfo.userYears!=null">user_years =
                #{userInfo.userYears}        -------------------(设置了userSex,从这个位置一直到where就会报错,而不是上面报错。)
            </if>

在此吸收的教训是,单元测试一定一定要全面。

如有疏漏请大佬们指正。

祝新年快乐。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值