`

关联关系

 
阅读更多
一对一单向外键关联
(学生卡表里有“studentId”字段)
public class Student {
	private int id;
	private String name;
}

public class StuIdCard {
	private int id;
	private String num;
         @OneToOne
	@JoinColumn(name="studentId")
	private Student student;
}

<hibernate-mapping>
	<class name="com.Student" dynamic-update="true">
		<id name="id">
			<generator class="native"/>
		</id>
		<property name="name"/>
    </class>
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.StuIdCard">
		<id name="id">
			<generator class="native"/>
		</id>
		<property name="num"/>
		<many-to-one name="student" column="studentId" unique="true"></many-to-one>
    </class>
</hibernate-mapping>



一对一双外键关联
(学生卡表里有“studentId”字段)
<hibernate-mapping>
	<class name="com.Student" dynamic-update="true">
		<id name="id">
			<generator class="native"/>
		</id>
		<property name="name"/>
		<one-to-one name="stuIdCard" property-ref="student"></one-to-one>
    </class>
</hibernate-mapping>

学生类添加
@OneToOne(mappedBy="student")
private StuIdCard stuIdCard;


多对一关联
public class User {
	private int id;
	private String name;
	@ManyToOne
	private Group group;
}

public class Group {
	private int id;
	private String name;
}

<hibernate-mapping>
	<class name="com.Group" table="t_group">
		<id name="id">
			<generator class="native"/>
		</id>		
		<property name="name"/>		
    </class>	
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.User" table="t_user">
		<id name="id">
			<generator class="native"/>
		</id>		
		<property name="name"/>
		<many-to-one name="group" column="groupId" />
    </class>	
</hibernate-mapping>

一对多关联
public class Group {
	private int id;
	private String name;
         @OneToMany
	@JoinColumn(name="groupId")
	private Set<User> users = new HashSet<User>();
}

public class User {
	private int id;
	private String name;
}

<hibernate-mapping>
	<class name="com.Group" table="t_group">
		<id name="id">
			<generator class="native"></generator>
		</id>		
		<property name="name"/>
		<set name="users">
			<key column="groupId"></key>
			<one-to-many class="com.User"/>
		</set>
    </class>
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.User" table="t_user">
		<id name="id">
			<generator class="native"></generator>
		</id>		
		<property name="name"></property>		
    </class>	
</hibernate-mapping>

一对多多对一关联
public class Group {
	private int id;
	private String name;
         @OneToMany(mappedBy="group")
	private Set<User> users = new HashSet<User>();
}

public class User {
	private int id;
	private String name;
	@ManyToOne
	private Group group;
}

<hibernate-mapping>
	<class name="com.Group" table="t_group">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="users">
			<key column="groupId"></key>
			<one-to-many class="com.User"/>
		</set>
    </class>
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.User" table="t_user">
		<id name="id">
			<generator class="native"></generator>
		</id>		
		<property name="name"></property>
		<many-to-one name="group" column="groupId"></many-to-one>
    </class>	
</hibernate-mapping>

多对多单向
public class Student {
	private int id;
	private String name;
}

public class Teacher {
	private int id;
	private String name;
	@ManyToMany
	@JoinTable(name="t_s",
		joinColumns={@JoinColumn(name="teacher_id")},
		inverseJoinColumns={@JoinColumn(name="student_id")}
		)
	private Set<Student> students = new HashSet<Student>();
}

<hibernate-mapping>
	<class name="com.Student">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
    </class>
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.Teacher">
		<id name="id">
			<generator class="native"></generator>
		</id>		
		<property name="name"></property>
		<set name="students" table="t_s">
			<key column="teacher_id"></key>
			<many-to-many class="com.Student" column="student_id"/>
		</set>
    </class>
</hibernate-mapping>

多对多两向关联
public class Student {
	private int id;
	private String name;
	@ManyToMany(mappedBy="students")
	private Set<Teacher> teachers = new HashSet<Teacher>();
}

public class Teacher {
	private int id;
	private String name;
	@ManyToMany
	@JoinTable(name="t_s",
		joinColumns={@JoinColumn(name="teacher_id")},
		inverseJoinColumns={@JoinColumn(name="student_id")}
		)
	private Set<Student> students = new HashSet<Student>();
}

<hibernate-mapping>
	<class name="com.Student">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="teachers" table="t_s">
			<key column="student_id"></key>
			<many-to-many class="comTeacher" column="teacher_id"/>
		</set>
    </class>
</hibernate-mapping>

<hibernate-mapping>
	<class name="com.Teacher">
		<id name="id">
			<generator class="native"></generator>
		</id>
		<property name="name"></property>
		<set name="students" table="t_s">
			<key column="teacher_id"></key>
			<many-to-many class="com.Student" column="student_id"/>
		</set>
    </class>
</hibernate-mapping>
分享到:
评论

相关推荐

    数据表的关联关系图-父表与子表的关联关系

    在数据库设计中,数据表之间的关联关系是至关重要的,它定义了不同表之间的逻辑联系,使得数据能够有效地组织和查询。本话题主要讨论的是“数据表的关联关系图”,特别是父表与子表的关联关系,涉及到的核心概念包括...

    解除与正常纳税人关联关系--个人声明.rar

    在税务管理中,个人与纳税人的关联关系是一个重要的概念,涉及到个人的税务责任、权益以及税务机关的管理工作。本文将详细解析标题“解除与正常纳税人关联关系--个人声明”所涉及的知识点,并根据提供的文件名“解除...

    hibernate关联关系实例

    在这个“hibernate关联关系实例”中,我们将深入探讨四种基本的关联关系:一对一(One-to-One)、一对多(One-to-Many)、多对一(Many-to-One)以及多对多(Many-to-Many),同时也会涉及Hibernate查询语言(HQL)...

    hibernate的关联关系映射

    【hibernate的关联关系映射】在Java持久化框架Hibernate中,关联关系映射是核心功能之一,它允许对象间的复杂关系与数据库中的表结构相匹配。在选课系统这个例子中,主要涉及到的对象包括课题(Course)、教师(Teacher...

    hibernate关联关系总结

    Hibernate关联关系是Java持久化框架Hibernate中的核心概念,它允许我们在数据库中建立对象之间的关系映射,以便在程序中操作对象时,可以自动处理与数据库的交互。本篇将深入探讨Hibernate的四种主要关联关系:一对...

    Hibernate映射一对多关联关系

    ### Hibernate映射一对多关联关系 #### 知识点概览 - **概念解析**:一对多(One-to-Many)关联关系的概念及其在Hibernate中的实现方式。 - **域模型设计**:创建具有一个实体与多个实体关联的域模型。 - **关系...

    hibernate多对一单向关联关系实现源码

    在Java的持久化框架Hibernate中,多对一(ManyToOne)关联关系是一种常见的对象关系映射(ORM)场景。这种关系通常出现在一个实体类拥有多条与另一个实体类相关的记录,而另一个实体类可能只有一条对应的记录。例如...

    五项说明关联关系PPT素材.rar

    标题中的“五项说明关联关系PPT素材”指的是一个PPT演示文稿,它可能包含五个部分,每个部分专门探讨一种或多种关联关系。在商业、数据分析或项目管理等领域,关联关系是理解不同元素间相互作用和影响的关键概念。这...

    关联关系.doc

    简单的关联关系的小例子: OneToOne: Person.java: package model; import javax.persistence.*; @Entity public class person { //标识属性 @Id @GeneratedValue(strategy=GenerationType.IDENTITY) private...

    企业授信客户隐性关联关系识别方法.pdf

    在当前金融行业风险管理领域中,企业授信客户隐性关联关系的识别是一个至关重要的环节。授信客户间的隐性关联关系往往不易察觉,却可能对金融机构的风险评估造成重大影响。因此,研究和开发一套有效的隐性关联关系...

    基于注解的关联关系Hibernate

    在这个“基于注解的关联关系Hibernate”的主题中,我们将深入探讨如何使用Hibernate的注解来配置不同类型的关联关系,包括一对一(One-to-One)、一对多(One-to-Many)、多对一(Many-to-One)和多对多(Many-to-...

    hibernate各种常用关联关系的基本配置

    关联关系是ORM中关键的概念,它模拟了现实世界中的实体之间的联系。本篇文章将深入探讨Hibernate中常见的几种关联关系及其基本配置。 一、一对一(OneToOne)关联 在一对一关联中,一个实体对象只对应数据库中的一...

    hibernate实现多对多关联关系源码

    在Java的持久化框架Hibernate中,多对多(Many-to-Many)关联关系是一种常见的实体间关系类型,它表示一个实体可以与多个其他实体相关联,反之亦然。本源码示例将深入探讨如何使用Hibernate来配置和管理这种复杂的...

    关联关系按条件查询细

    在软件开发中,尤其是在涉及到数据库操作的场景,关联关系按条件查询是一项基础且重要的技能。关联关系是指在数据库设计中,不同表之间的联系,如一对一、一对多、多对多等。本文主要讨论了如何在Java环境下,利用...

    hibernate一对一关联关系

    在实体类之间,Hibernate支持多种关联关系,包括一对一(One-to-One)、一对多(One-to-Many)和多对多(Many-to-Many)。本资源主要探讨的是“hibernate一对一关联关系”。 一对一关联关系在现实世界中很常见,...

    MyBatis3关联关系

    在处理复杂的数据库关联关系时,MyBatis 提供了一对一、一对多、多对多等多种映射方式,使得数据模型的构建和数据查询变得更加灵活。 ### 一对一映射 1. **查询方式**:在 MyBatis 中,一对一映射可以通过圆点记法...

    基于企业知识图谱的企业关联关系挖掘.docx

    基于企业知识图谱的企业关联关系挖掘.docx

    Hibernate 多对一关联关系的例子

    本示例将深入探讨如何在Hibernate中实现多对一的关联关系。 首先,让我们理解多对一关联的基本概念。假设我们有两个实体,一个是`Employee`(员工),另一个是`Department`(部门)。在实际业务场景中,一个部门...

    Hibernate关联关系

    ### Hibernate关联关系详解 在Java开发领域中,Hibernate作为一个强大的对象关系映射(ORM)框架,为开发者提供了方便地操作数据库的方式。通过将Java对象与数据库表进行映射,Hibernate大大简化了数据持久化层的...

Global site tag (gtag.js) - Google Analytics