hibernate级联更新(自动识别哪些字段变化了)

hibernate做更新操作的时候,

比如我有一个订单表order,

一个乘机人表passenger,

还有一个航班信息表flight,

order与passenger一对多的关系,

order与flight一对多的关系,

0:如果查询出来没有做任何修改,进行更新

hibernate不会做更新处理,不会执行sql语句。

1:只更新order表中的数据

hibernate首先会根据外键查询订单下面对应passenger和flight表中的信息。执行2条sql

然后执行一条更新order的sql语句。

原理,级联更新的时候,主关联的表有变动,会先把被关联的查询出来看,是否可以做级联操作。

2:如果order表没有做任何修改,passenger表修改了

因为order表没有变,所以不会先查询passenger和flight表中的信息,不会多产生2条查询sql语句。

然后更新数据变化了的记录,更新变化了的字段。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值