Hibernate中的merge使用详情解说
2023-03-14 22:46:11 时间
merge的作用是:新new一个对象,如果该对象设置了ID,则这个对象就当作游离态处理:
当ID在数据库中不能找到时,用update的话肯定会报异常,然而用merge的话,就会insert。
当ID在数据库中能找到的时候,update与merge的执行效果都是更新数据,发出update语句;
如果没有设置ID的话,则这个对象就当作瞬态处理:
用update的话,由于没有ID,所以会报异常,merge此时则会保存数据,根据ID生产策略生成一条数据;
- Session session1 = HibernateUtils.getSession();
- Transaction transaction1 = session1.beginTransaction();
- Students str1 = new Students();
- str1.setStu_id(4);
- str1.setName("222");
- session1.merge(str1);
- str1.setName("333");
- transaction1.commit();
- session1.clear();
- session1.close();
下面是当对象在第一个session关闭后,处于游离状态,第二个session开启,又get或load一样的ID的数据出来时,在第二个session中update那个游离态对象,update肯定会出错,原因是程序会报持久层中已经有该对象,因为第二个session重新从数据库中获取了一个对象成持久态,你的update会让那个游离态对象也变成持久态,两个持久态会冲突撒,然而用merge的话,它会把第一个的对象数据赋值给已经处于持久化的那个对象中,自己本身不得变为持久态;(这个我测试很多到的,没问题)
- Session session1 = HibernateUtils.getSession();
- Transaction transaction1 = session1.beginTransaction();
- Students str1 = (Students)session1.get(Students.class, 2);
- transaction1.commit();
- session1.clear();
- session1.close();
- Session session2 = HibernateUtils.getSession();
- Transaction transaction2 = session2.beginTransaction();
- Students str2 = (Students)session2.get(Students.class, 2);
- session2.merge(str1);
- transaction2.commit();
- session2.clear();
- session2.close();
- Session session2 = HibernateUtils.getSession();
- Transaction transaction2 = session2.beginTransaction();
- Students str2 = (Students)session2.get(Students.class, 2);
- str1.setName("wer");
- session2.merge(str1);
- System.out.println(str2.getName()); //这里改变了,说明持久态的数据也会改变
- str2.setName("ee");
- System.out.println(str1.getName()); //这里不会改变,说明第一个游离态的数据没有被持久化撒;
- transaction2.commit();
- session2.clear();
- session2.close();
原文链接:http://blog.csdn.net/lang_man_xing/article/details/7572964
相关文章
- MySQL备份操作
- es实战-Monitoring原理讲解及kibana可视化实战
- CCCF专栏 | 加密数据库技术:前沿与展望
- PostgreSQL插件汇总
- SQL 语句
- 图像分类-flower_photos 实验研究
- MySQL 用户和权限管理
- MySql数据库列表数据分页查询、全文检索API零代码实现
- 创建数据文件:恢复一个备份中没有的数据文件
- 基于阿里云函数计算实现AI推理
- 基于Redis实现在线游戏积分排行榜
- 快手基于 Flink 构建实时数仓场景化实践
- 明明白白使用数据块 —-数据块格式深入解析
- Flink 状态管理-快照策略
- 大数据Flink最佳实践|阿里云产品内容精选(二十五)
- Oracle学习路线与方法
- 一篇搞懂什么是数据中台 | 开发者社区精选文章合集(二十五)
- MaxCompute使用指南
- Elasticsearch 跨集群数据迁移方案总结
- 浙江珍琦护理用品CIO窦新明:业务数据化与数据业务化需有机结合 | 阿里云研究院名人堂