文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Hibernate中merge()方法的作用是什么

2023-06-17 21:31

关注

Hibernate中merge()方法的作用是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

具体的实现过程如下:

背景:
◆Account 和 Group 两个对象,设置了双向的many-to-many关系,lazy=true

◆不使用open session in view 模式

◆不使用hibernate二级缓

◆考虑web应用场景,设置account和group关联时,只需要group和account的id就够了。

◆数据库中存在两个group: 1.administrators, 2.engineers而po对象中,group信息为:1.invalid, 2.any one

代码A:

Account account = (Account) getHibernateTemplate().merge(po);     Long id = account.getId();     System.out.println("\tGet obj after added in dao start ...");     Account readAccount = (Account) getHibernateTemplate().get(         Account.class, id);     System.out.println("\tGet obj after added in dao end ...");     System.out.println("\tIs po==readAccount ? " + (po == readAccount));     System.out.println("\tShow detai of po: " + po.toDetailString());     System.out.println("\tShow detai of readAccount: " + readAccount.toDetailString());

其中,为po设置了两个group 输出结果:

Hibernate: select ... from SYS_GROUPS where ID=?     Hibernate: select ... from SYS_GROUPS where ID=?         Get obj after added in dao start ...         Get obj after added in dao end ...         Is po==readAccount ? false        Show detai of po: Account[0.account_22, groups[2.any one 1.invalid ]]         Show detai of readAccount: Account[22.account_22, groups[2.engineers 1.administrators ]]     Hibernate: insert into SYS_ACCOUNTS (...) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)     Hibernate: insert into SYS_GROUP_MEMBER (ACCOUNT_ID, GROUP_ID) values (?, ?)     Hibernate: insert into SYS_GROUP_MEMBER (ACCOUNT_ID, GROUP_ID) values (?, ?)

代码B:

Long id = (Long) getHibernateTemplate().save(po);     System.out.println("\tGet obj after added in dao start ...");     Group group = (Group)getHibernateTemplate().get(Group.class,new Long(1));     System.out.println("\tGroup detai:" + group.toString());     Account readAccount = (Account) getHibernateTemplate().get(         Account.class, id);     System.out.println("\tGet obj after added in dao end ...");     System.out.println("\tIs po==readAccount ? " + (po == readAccount));     System.out.println("\tShow detai of po: " + po.toDetailString());     System.out.println("\tShow detai of readAccount: "        + readAccount.toDetailString());         getHibernateTemplate().merge(readAccount);     Account readAgain = (Account) getHibernateTemplate().get(Account.class,         id);     System.out.println("\tIs po==readAgain ? " + (readAgain == po));     System.out.println("\tIs readAgain== readAccount? "        + (readAgain == readAccount));     System.out.println("\tShow detai again: " + readAgain.toDetailString());

输出结果:

    Get obj after added in dao start ...     Hibernate: select ... from SYS_GROUPS where ID=?         Group detai:Group 1. administrators         Get obj after added in dao end ...         Is po==readAccount ? true        Show detai of po: Account[27.account_27, groups[1.invalid 2.any one ]]         Show detai of readAccount: Account[27.account_27, groups[1.invalid 2.any one ]]     Hibernate: select ... from SYS_GROUPS where ID=?         Is po==readAgain ? true        Is readAgain== readAccount? true        Show detai again: Account[27.account_27, groups[1.administrators 2.engineers ]]     Hibernate: insert into SYS_ACCOUNTS (...) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)     Hibernate: insert into SYS_GROUP_MEMBER (ACCOUNT_ID, GROUP_ID) values (?, ?)     Hibernate: insert into SYS_GROUP_MEMBER (ACCOUNT_ID, GROUP_ID) values (?, ?)

结论:

Hibernate merge()方法会导致执行查询group对象的select语句,在调用merge()命令时立即执行(条件:目标group对象没有被缓存)

无论Hibernate merge()或save()方法,insert语句都在***执行,并非在调用相应命令时立即执行

直接调用merge()方法时,会返回一个新的instance,原po保持不变

save()之后,po中的group对象并没有被关联到session,因此查询group(id=1)会触发select语句

save()之后,po对象被关联到session,再次查询,不会触发select语句,并且不会检查group对象是否被关联到session

save()之后再调用merge,返回的是同一个instance,但其关联group对象会被更新

如果在add一个对象之后,如果存在关联对象,并且需要再同一个hibernate session中进行回显,则建议使用Hibernate merge()方法。

看完上述内容,你们掌握Hibernate中merge()方法的作用是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯