Hibernate如何用@DynamicUpdate(true)动态更新字段

网上说动态更新字段大致分为两步:

  1. 添加@DynamicUpdate(true)注解;
  2. 使用session为我们提供的merge方法

,具体可以看这篇博客:

https://dreamzhong.iteye.com/blog/1207377

一开始我没有使用merge()来更新字段,而是直接用Update()方法来更新,所以失败了,而merge方法是先查询数据库里的所以字段,然后与对应的实体类比较哪个字段有更新,然后再动态生成sql语句来更新对应的字段,但我调用这个方法之后控制台输出如下信息,其中实体类里面只有userName的值与数据库中的不同,可以看出merge的执行流程就是这样的

Hibernate: 
    select
        user0_.userid as userid1_0_0_,
        user0_.activationCode as activati2_0_0_,
        user0_.address as address3_0_0_,
        user0_.email as email4_0_0_,
        user0_.headPhoto as headPhot5_0_0_,
        user0_.password as password6_0_0_,
        user0_.phone as phone7_0_0_,
        user0_.realName as realName8_0_0_,
        user0_.state as state9_0_0_,
        user0_.userName as userNam10_0_0_ 
    from
        user user0_ 
    where
        user0_.userid=?
Hibernate: 
    update
        user 
    set
        userName=? 
    where
        userid=?

这样就是实现了动态更新字段

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值