3 MyBatis动态SQL之set标签|转

1 MyBatis动态SQL之if 语句
2 MyBatis动态sql之where标签|转
3 MyBatis动态SQL之set标签|转
4 MyBatis动态SQL之trim元素|转
5 MyBatis动态sql中foreach标签的使用
6 MyBatis动态SQL之choose(when、otherwise)语句
7 MyBatis动态SQL之bind标签|转

  关于动态更新语句还可以使用set元素,它可以被用于动态包含需要更新的列,而舍去其它的。set标记是MyBatis提供的一个智能标记,我一般将其用在修改的sql中,例如下述场景:

<update>

  update tb_employee 
       <set>
      <if test="name != null and name.length()>0">name = #{name},</if>
      <if test="sex != null and gender.length()>0">sex = #{sex},</if>
          <if test="age != null">age=#{age},</if>
          <if test="phone != null">phone=#{phone},</if>
    </set>
    where id = #{id}
  </update>

  set元素会动态前置SET关键字,同时也会自动抹去where查询条件前多余的逗号,避免因为使用条件语句在生成赋值语句的后面留下不需要的逗号。在上述的代码片段当中,假如前三个字段都有值,那么在控制台打印的SQL语句如下:

update tb_employee set name='xxx', sex='xx', age='yyy' where id='x'

  在上面yyy的后面是没有逗号的,也就是说set标记已经智能地帮助我们把最后一个逗号给去掉了。

  来看看与 set 元素等价的自定义 trim 元素吧:

<trim prefix="SET" suffixOverrides=",">
  ...
</trim>

  注意,我们覆盖了后缀值设置,并且自定义了前缀值。

Reference

posted @ 2022-03-30 08:06  楼兰胡杨  阅读(756)  评论(0编辑  收藏  举报