返回顶部
首页 > 资讯 > 精选 >Hibernate多对多怎么实现
  • 664
分享到

Hibernate多对多怎么实现

2023-06-03 07:06:39 664人浏览 独家记忆
摘要

本篇内容主要讲解“Hibernate多对多怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate多对多怎么实现”吧!假設現在有User與Server兩個類別,一個User可以被

本篇内容主要讲解“Hibernate多对多怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate多对多怎么实现”吧!

假設現在有User與Server兩個類別,一個User可以被授權使用多台Server,而在Server上也記錄授權使用它的使用者,就User與Server兩者而言即使多對多的關係。

在程式設計時,基本上是不建議直接在User與Server之間建立多對多關係,這會使得User與Server相互依賴,通常會透過一個中介類別來維護兩者之間的多對多關係,避免兩者的相互依賴。

如果一定要直接建立User與Server之間的多對多關係,Hibernate也是支援的,基本上只要您瞭解之前介紹的幾個實體映射,建立多對多關聯在配置上並不困難。

先看一下我們設計的User與Server類別:

java 代码

  1. package onlyfun.caterpillar;

  2. import java.util.*;

  3. publicclass User {

  4. privatelong id;

  5. private String name;

  6. private Set servers = new HashSet();

  7. publiclong getId() {

  8. return id;

  9. }

  10. publicvoid setId(long id) {

  11. this.id = id;

  12. }

  13. public String getName() {

  14. return name;

  15. }

  16. publicvoid setName(String name) {

  17. this.name = name;

  18. }

  19. public Set getServers() {

  20. return servers;

  21. }

  22. publicvoid setServers(Set servers) {

  23. this.servers = servers;

  24. }

  25. }

java 代码

  1. package onlyfun.caterpillar;

  2. import java.util.*;

  3. publicclass Server {

  4. privatelong id;

  5. private String address;

  6. private Set users = new HashSet();

  7. publiclong getId() {

  8. return id;

  9. }

  10. publicvoid setId(long id) {

  11. this.id = id;

  12. }

  13. public String getAddress() {

  14. return address;

  15. }

  16. publicvoid setAddress(String address) {

  17. this.address = address;

  18. }

  19. public Set getUsers() {

  20. return users;

  21. }

  22. publicvoid setUsers(Set users) {

  23. this.users = users;

  24. }

  25. }

這邊各使用HashSet來保存彼此的關係,在多對多關係映射上,我們可以建立單向或雙向關係,這邊直接介紹雙向關係映射,並藉由設定inverse="true",將關係的維護交由其中一方來維護,這麼作的結果,在原始碼的撰寫上,也比較符合Java的物件關係維護,也就是雙方都要設置至對方的參考。

首先來看看User.hbm.xml:

xml 代码

  1. xmlversion="1.0"?>

  2. PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"

  3. "Http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

  4. <hibernate-mapping>

  5. <classname="onlyfun.caterpillar.User"table="USER">

  6. <idname="id"column="USER_ID"unsaved-value="0">

  7. <generatorclass="increment"/>

  8. id>

  9. <propertyname="name">

  10. <columnname="NAME"length="16"not-null="true"/>

  11. property>

  12. <setname="servers"

  13. table="USER_SERVER"

  14. cascade="save-update">

  15. <keycolumn="USER_ID"/>

  16. <many-to-manyclass="onlyfun.caterpillar.Server"

  17. column="SERVER_ID"/>

  18. set>

  19. class>

  20. hibernate-mapping>

在資料庫中,資料表之間的多對多關係是透過一個中介的資料表來完成,例如在這個例子中,USER資料表與USER_SERVER資料表是一對多,而USER_SERVER對SERVER是多對一,從而完成USER至SERVER的多對多關係,在USER_SERVER資料表中,將會有USER_ID與SERVER_ID共同作為主鍵,USER_ID作為一個至USER的外鍵參考,而SERVER_ID作為一個至SERVER的外鍵參考。

來看看Server.hbm.xml映射文件:

xml 代码

  1. xmlversion="1.0"?>

  2. PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"

  3. "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

  4. <hibernate-mapping>

  5. <classname="onlyfun.caterpillar.Server"table="SERVER">

  6. <idname="id"column="SERVER_ID"unsaved-value="0">

  7. <generatorclass="increment"/>

  8. id>

  9. <propertyname="address"type="string"/>

  10. <setname="users"

  11. table="USER_SERVER"

  12. inverse="true"

  13. cascade="save-update">

  14. <keycolumn="SERVER_ID"/>

  15. <many-to-manyclass="onlyfun.caterpillar.User"

  16. column="USER_ID"/>

  17. set>

  18. class>

  19. hibernate-mapping>

設置上與User.hbm.xml是類似的,只是增加了inverse="true",表示將關係的維護交由另一端,注意我們在User與Server的cascade都是設置為save-update,在多對多的關係中,all、delete等cascade是沒有意義的,因為多對多中,並不能因為父物件被刪除,而造成被包括的子物件被刪除,因為可能還有其它的父物件參考至這個子物件。

我們使用下面這個程式來測試:

java 代码

  1. import onlyfun.caterpillar.*;

  2. import net.sf.hibernate.*;

  3. import net.sf.hibernate.cfg.*;

  4. publicclass HibernateTest {

  5. publicstaticvoid main(String[] args) throws HibernateException {

  6. SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();

  7. Server server1 = new Server();

  8. server1.setAddress("PC-219");

  9. Server server2 = new Server();

  10. server2.setAddress("PC-220");

  11. Server server3 = new Server();

  12. server3.setAddress("PC-221");

  13. User user1 = new User();

  14. user1.setName("caterpillar");

  15. User user2 = new User();

  16. user2.setName("momor");

  17. user1.getServers().add(server1);

  18. user1.getServers().add(server2);

  19. user1.getServers().add(server3);

  20. server1.getUsers().add(user1);

  21. server2.getUsers().add(user1);

  22. server3.getUsers().add(user1);

  23. user2.getServers().add(server1);

  24. user2.getServers().add(server3);

  25. server1.getUsers().add(user2);

  26. server3.getUsers().add(user2);

  27. Session session = sessionFactory.openSession();

  28. Transaction tx= session.beginTransaction();

  29. session.save(user1);

  30. session.save(user2);

  31. tx.commit();

  32. session.close();

  33. sessionFactory.close();

  34. }

  35. }

注意由於設定了inverse="true",所以必須分別設定User與Server之間的相互參考,來看看實際上資料庫中是如何儲存的:

select * FROM USER

+---------+-------------+
| USER_ID | NAME |
+---------+-------------+
| 1 | caterpillar |
| 2 | momor |
+---------+-------------+

select * FROM USER_SERVER

+-----------------+--------------+
| SERVER_ID | USER_ID |
+-----------------+--------------+
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 1 | 2 |
| 2 | 2 |
+-----------------+--------------+

select * FROM SERVER

+-----------------+------------+
| SERVER_ID | address |
+-----------------+------------+
| 1 | PC-219 |
| 2 | PC-221 |
| 3 | PC-220 |
+-----------------+-------------+

到此,相信大家对“Hibernate多对多怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Hibernate多对多怎么实现

本文链接: https://lsjlt.com/news/233353.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Hibernate多对多怎么实现
    本篇内容主要讲解“Hibernate多对多怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate多对多怎么实现”吧!假設現在有User與Server兩個類別,一個User可以被...
    99+
    2023-06-03
  • Hibernate一对多怎么实现
    本篇内容主要讲解“Hibernate一对多怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate一对多怎么实现”吧!先看由满江红翻译团队(RedSaga Translate T...
    99+
    2023-06-17
  • Hibernate中怎么实现多对一和一对多操作
    这期内容当中小编将会给大家带来有关Hibernate中怎么实现多对一和一对多操作,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、多对一和一对多概念其实这个概念上来说很简单,比如一个客户可以有多个订单,多...
    99+
    2023-06-17
  • Hibernate一对多数据关联怎么实现
    本篇内容主要讲解“Hibernate一对多数据关联怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate一对多数据关联怎么实现”吧!数据模型表定义sqluse sam...
    99+
    2023-06-17
  • Hibernate的一对一,一对多/多对一关联保存的实现
    目录一对一关联保存:留言表实体类配置:(主表)留言内容表配置:(从表)留言表hbm.xml配置:(主表)留言内容表hbm.xml配置:(从表)一对多/多对一保存活动表实体类配置:(主...
    99+
    2024-04-02
  • hibernate 多对多关系映射
    学生 和 课程就是一种多对多的关系映射,那么再hibernate中,对于多对多关系在怎么配置?和一些注意的事项?简单测试下。建表实体配置文件和映射测试1。使用oracle ,建表sqlcreate ...
    99+
    2024-04-02
  • 利用Hibernate怎么实现一个多对一单项关联
    这期内容当中小编将会给大家带来有关利用Hibernate怎么实现一个多对一单项关联,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。概念      ...
    99+
    2023-05-31
    hibernate te
  • Hibernate中的多表查询怎么实现
    本篇内容介绍了“Hibernate中的多表查询怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、 Hibernate简介Hibern...
    99+
    2023-06-17
  • Hibernate多表关联查询怎么实现
    本篇内容介绍了“Hibernate多表关联查询怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、Hibernate简介Hiberna...
    99+
    2023-06-17
  • Java Hibernate中一对多和多对多关系的映射方式
    目录Hibernate的一对多和多对多Hibernate的一对多Hibernate的一对多配置Hibernate的一对多操作Hibernate的多对多Hibernate的多对多配置H...
    99+
    2023-05-18
    Java Hibernate一对多 Java Hibernate多对多
  • hibernate 一对多 关系映射
    在关系中,或多或少的表之间有复杂的关联关系这里测试 一对多 关联关系的配置开发步骤就不多说了。直接看一个示例。users 用户 和  shop商品订单表分析:一个用户可以有多个商品订单,一个订单只...
    99+
    2024-04-02
  • Hibernate一对多数据关联是什么
    本篇内容主要讲解“Hibernate一对多数据关联是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate一对多数据关联是什么”吧!Hibernate一对多数据关联。指的是单向一对...
    99+
    2023-06-17
  • JSP 开发之hibernate的hql查询多对多查询
    JSP 开发之hibernate的hql查询多对多查询在hibernate的hql查询中,假如说分组信息与试题是多对多关系,那么我们要在hql查询中对含有多个分组信息的试题都要查询出来。并同时查询出相应试题的分组信息。那么此时hql要这样写...
    99+
    2023-05-31
    hibernate 多对多 查询
  • MyBatis中怎么实现一对多查询和多对一查询
    这篇“MyBatis中怎么实现一对多查询和多对一查询”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MyBatis中怎么实现一...
    99+
    2023-06-29
  • mybatis怎么实现一对多映射
    这篇文章主要讲解了“mybatis怎么实现一对多映射”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatis怎么实现一对多映射”吧!mybatis 一对多映射 column属性注意事项昨...
    99+
    2023-06-26
  • Python socket实现多对多全双
    服务器:#server.py#!/usr/bin/env python #-*-coding:utf-8-*- import sys import ...
    99+
    2023-01-31
    Python socket 多全双
  • MyBatis如何实现多表查询(多对一、一对多)
    MyBatis实现多表查询  一、多对一查询 数据库的准备 创建两张表,一张老师表,一张学生表 将老师主键id关联学生外键tid 创建sql的语句 create ta...
    99+
    2024-04-02
  • Hibernate映射一对多关联关系是什么
    这篇文章主要讲解了“Hibernate映射一对多关联关系是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Hibernate映射一对多关联关系是什么”吧!在域模型中,类和类之间最普通的关系...
    99+
    2023-06-17
  • 详解hibernate双向多对多关联映射XML与注解版
    双向多对多关联映射原理:假设,一个员工可能有多个角色,一个角色可能有多个员工,从员工或角色的角度看,这就是多对多的关系,不管从哪一个角度看,都是多对多的联系。多对多关联映射关系一般采用中间表的形式来实现,即新增一种包含关联双方主键的表。实现...
    99+
    2023-05-31
    hibernate 映射 te
  • SpringBoot中Mybatis注解一对多和多对多查询实现示例
    目录一、模拟的业务查询二、对应的实体类如下三、对应的建表语句和模拟数据如下四、@One一对一映射五、@Many一对多查询六、@One @Many的总结一、模拟的业务查询 系统中的用户...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作