merge的作用是:新new一个对象,如果该对象设置了ID,则这个对象就当作游离态处理:
创新互联公司制作网站网页找三站合一网站制作公司,专注于网页设计,成都网站建设、做网站,网站设计,企业网站搭建,网站开发,建网站业务,680元做网站,已为1000多家服务,创新互联公司网站建设将一如既往的为我们的客户提供最优质的网站建设、网络营销推广服务!
当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使用详情解说
网站URL:http://www.shufengxianlan.com/qtweb/news26/28926.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联