Hibernate中的merge使用详情解说
来源:互联网 发布:中昌数据股票最新消息 编辑:程序博客网 时间:2024/05/10 23:57
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();
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- Hibernate中的merge使用详情解说
- 使用Hibernate 中的merge()方法
- Hibernate中的session.merge()使用
- PDF.js 详情解说
- Hibernate中的merge方法详解
- oracle中的merge使用
- DOS中的echo命令使用详情
- JavaScript中的事件使用方式解说
- Hibernate 中的 merge方法何解?
- SQL2008中的MERGE使用心得
- oracle中的MERGE的使用
- Hibernate中merge的详细使用
- postgresql pg_buffercache
- 手机尾号评分
- unity3d摄影机晃动特效【脚本】
- Win下rjb安装
- CAP原理和BASE思想
- Hibernate中的merge使用详情解说
- oracle share server
- Android常用属性
- 关于super.getClass().getName()
- js闭包如此简单
- 手机问题
- 全局偏移表(GOT)和过程链接表(PLT)
- Hadoop本地库与系统版本不一致引起的错误解决方法
- 数据聚类综述第5章——聚类技术