w100224 2017-05-15 15:27 采纳率: 85.7%
浏览 1791
已采纳

hibernate一对多级联保存机制是什么

Configuration configuration = new Configuration().configure();
SessionFactory sessionFactory = configuration.buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();

    Order order = new Order();
    order.setOrderName("订单2");

    Ticket ticket = new Ticket("优惠券1",order);
    Ticket ticket1 = new Ticket("优惠券2",order);
    order.getTickets().add(ticket);
    order.getTickets().add(ticket1);

    session.save(order);

    transaction.commit();
    session.close();
    sessionFactory.close();
 我明明只执行了订单order的save操作,其中一个order对应多个ticket优惠券,为什么输出的sql中 是执行了对应的三个insert语句后,又执行了两次ticket优惠券的update?这里的update语句是干啥的,一对多级联保存机制是什么

这是打印的sql:
Hibernate:
insert
into
bc_order
(orderName)
values
(?)
Hibernate:
insert
into
bc_ticket
(ticketName, orderId)
values
(?, ?)
Hibernate:
insert
into
bc_ticket
(ticketName, orderId)
values
(?, ?)
Hibernate:
update
bc_ticket
set
orderId=?,
p_index=?
where
ticketId=?
Hibernate:
update
bc_ticket
set
orderId=?,
p_index=?
where
ticketId=?

  • 写回答

1条回答

  • AngusC· 2017-05-15 15:30
    关注

    原因很简单,你问为什么会发出很多的update的SQL语句(如果你将SET标签添加上inverse="true"就不会有这样的情况,反转交给多的一方来维护),因为你现在是在让一的一方来维护关系:举个例子class和 student测试存储的方法中,
    (1)你要先NEW出几个Order 对象
    (2)创建一个SET集合,并添加Order 实体对象
    (3)创建一个class对象,给这个实体的保留Order SET集合的属性Order 赋值
    (4)session.save(class);
    你如果你要直接运行这个方法的话,会抛出transiont objecte excption 异常,因为在(1)中你的Order 对象为transient状态,要转化为persistent状态,要session.save(Order );....都要save;
    ----此时你会在输出端会看到hibernate发出了SQL insert语句,但是外键现在没有值
    此时你的数据库student表中,外键字段class_id那列为里面都是NULL值,
    接着执行,当session.save(class);
    -----此时你才会看到hibernate发出了SQL update语句:
    只要就是为了update Order set class_id=".."where id="..",故存在几个Order 实体对象,就会发出几个update 。
    通过上面可以看出它的缺点也就是:
    第一:如果你将Order 表里的class_id字段设置为空,你就会无法保存数据;
    第二:在class一方的一端会发出多余的update语句,你可以想象如果我要存1000个订单,那么你在一的一方维护关系,它就会发出1000条update。。。。。。
    一般不重要做,都是添上inverse=“true”反转给多的一方维护即可!
    你可以在Eclipe 写测试方法设置断点来调试看下!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题