在做一个项目的过程中,发现一个问题。
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>
在此吸收的教训是,单元测试一定一定要全面。
如有疏漏请大佬们指正。
祝新年快乐。