Mybatis动态sql_set标签

1、作用

代替set关键字以及

根据传入参数情况自动去除多余的,号。

2、需求

更新用户生日和性别

更新用户生日

3、示例

测试

@Test 
public void testSet(){ 
SqlSession sqlSession = SqlSessionKit.openSession(true); 
UserMapper mapper = sqlSession.getMapper(UserMapper.class); 
// 更新内容 
User user = new User(); 
user.setId(1); 
user.setBirthday(new Date()); 
// user.setSex("2"); 
mapper.update(user); 
}

操作

/*** 更新用户. ** @param user 用户信息 */ 
void update(User user);

配置

<update id="update" parameterType="com.itheima.mybatis.day03.sql.model.User"> 
update user 
<set>
<if test="birthday!=null"> 
birthday=#{birthday}, 
</if> 
<if test="sex!=null and sex!=''"> 
sex=#{sex}, 
</if> 
</set> 
where id = #{id} 
</update>

结果

DEBUG [main] - Created connection 173738886. DEBUG [main] - ==> Preparing: update user SET

birthday=? where id = ? DEBUG [main] - ==> Parameters: 2019-04-16 17:48:09.417(Timestamp),

1(Integer) DEBUG [main] - <== Updates: 1

4、注意

set标签无论外部有没有set关键字都会为最终sql添加set

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值