你是否想达到下列目的:
budgetType 不为null,更新 BUDGET_TYPE_ 字段;
budgetType 为努力时,不更新 BUDGET_TYPE_ 字段;
如果是可以如下做:
<update id="update">UPDATE PRO_BUDGET_F
SET
<if test="budgetType != null"> BUDGET_TYPE_ = #{budgetType}</if>
<if test="budgetType == null"> BUDGET_TYPE_ = BUDGET_TYPE_</if>
WHERE ID_ = #{id}
</update>
即改变下思路,当budgetType 为null,不更新值(这里BUDGET_TYPE_ = BUDGET_TYPE_
只是把值重新设置一次)
注:上面的方法只是针对你Mybatis部分做出的修改,如果budgetType 为null,将执行一次无用的SQL语句,浪费系统资源,最好的办法是,到调用Mybatis时(一般在DAO)判断budgetType是否为空,为空则不执行数据库 *** 作;
Mybatis只执行SQL *** 作,Dao(或者Service)附带业务检查,判断是否需要执行
两者是有区别的:1堆栈中:假设声明String s1 = null;String s2 = “”;
其实上栈中会有存放s1,但是堆中没有产生数据;但是对于第二条语句,不仅栈中有s2,堆中也会有“”(空字符串,假如以前存在的话,s2会直接指向,假如没有,就会新建一个);
2方法引用:s1为null,不能调用String的任何方法,否则会报NullPointerException异常;而“”则可以调用String的任何方法,如字符串的拼接或者是求长度等。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)