mybatis中一个逗号引发的血案

探讨了在使用MyBatis框架进行数据库更新操作时,由于条件判断与逗号缺失导致的潜在错误,强调了单元测试的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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>

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

如有疏漏请大佬们指正。

祝新年快乐。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值