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
读后有收获,小礼物走一走,请作者喝咖啡。
Buy me a coffee. ☕Get red packets.
作者:楼兰胡杨
本文版权归作者和博客园共有,欢迎转载,但请注明原文链接,并保留此段声明,否则保留追究法律责任的权利。