SQL:class_course是中间表
create table class (
id number(10,0) not null,
name varchar2(15) not null,
sdate date,
edate date,
primary key (id)
);
create table class_course (
classid number(10,0) not null,
courseid number(10,0) not null,
primary key (classid, courseid)
);
create table course (
id number(10,0) not null,
name varchar2(15) not null,
perion number(10,0),
primary key (id)
);
alter table class_course
add constraint fk_class
foreign key (classid)
references class(id);
alter table class_course
add constraint fk_course
foreign key (courseid)
references course(id);
POJO:都有对方的一个引用(以下为省略写法)
public class TarenaClass implements Serializable
{
private Set<TarenaCourse> courses = new HashSet<TarenaCourse>();
}
public class TarenaCourse implements Serializable
{
private Set<TarenaClass> classes = new HashSet<TarenaClass>();
}
XML: TarenaClass.hbm.xml TarenaCourse.hbm.xml(以下为省略写法)
<hibernate-mapping package="com.allanlxf.hibernate.association.m2m.entity" >
<class name="TarenaClass" table="class" >
<id name="id" column="id" type="integer">
<generator class="native" />
</id>
<set name="courses" table="class_course" cascade="persist" lazy="false">
<key column="classid" />
<many-to-many class="TarenaCourse" column="courseid" foreign-key="fk_course"/>
</set>
</class>
</hibernate-mapping>
<hibernate-mapping package="com.allanlxf.hibernate.association.m2m.entity">
<class name="TarenaCourse" table="course">
<id name="id" column="id" type="integer">
<generator class="native" />
</id>
<set name="classes" table="class_course" inverse="true">
<key column="courseid" />
<many-to-many class="TarenaClass" column="classid" foreign-key="fk_class"/>
</set>
</class>
</hibernate-mapping>
a) session.save(class);
session.save(course);
这里的两个保存方法可以分开执行。
b) 向关联表插入数据:
TarenaClass tarenaClass = classService.findById(46);
TarenaCourse tarenaCourse = courseService.findById(47);
tarenaClass.getCourses().add(tarenaCourse);
tarenaCourse.getClasses().add(tarenaClass);
session.update(tarenaClass);
many-to-many外键双向关联总结: 双方的XML在set集合中都通过设置中间表来做关联操作,并使用inverse="true"指定主控方
分享到:
相关推荐
本篇将详细讲解如何使用Hibernate实现一对一唯一外键(Unique Foreign Key)关联映射,并以双向关联为例进行深入探讨。 一、Hibernate一对一关联类型 一对一关联在现实世界中很常见,例如一个人只有一个身份证,一...
在Java的持久化框架Hibernate中,一对一(One-to-One)关联映射是常见的关系数据库模型在对象模型中的体现。...对于更复杂的双向关联或者其他关联类型,可以参考Hibernate官方文档或更多教程进行深入学习。
在本教程中,我们将深入探讨Hibernate中的一个关键概念——关系映射,特别是“一对一”双向外键关联。这种关联类型在数据库设计中很常见,尤其是在处理具有紧密耦合的实体时。Hibernate作为Java中广泛使用的对象关系...
Hibernate 一对一唯一外键关联映射详解 Hibernate是一种流行的Java持久层框架,提供了多种关联映射方式,其中一对一唯一外键关联映射是一种常见的关联方式。在本文中,我们将详细介绍Hibernate一对一唯一外键关联...
本篇主要探讨的是Hibernate中的一对一(OneToOne)关系映射,特别是唯一外键关联(UniDirectional and Bidirectional Association)的情况。我们将深入理解这种关联方式的配置、实现以及它在实际应用中的价值。 1. ...
在Java的持久化框架...总之,一对一唯一外键双向关联在Hibernate中提供了强大的对象关系映射能力,但需要谨慎处理,以防止潜在的问题。理解并正确配置这种关联关系对于提升Java应用程序的持久化层设计至关重要。
在实际开发中,使用IDEA等集成开发环境可以自动生成一对一双向关联的实体类和映射文件,方便快捷。同时,通过数据库管理工具如MySQL Workbench,可以直观地查看表结构和外键约束,帮助理解一对一关联的实际效果。 ...
本篇将深入探讨Hibernate中的一对一唯一外键关联映射,特别是双向关联的实现。 ### 1. 一对一关联概述 一对一关联意味着一个实体只能与另一个实体的单一实例相关联,这种关系通常出现在两个表之间,其中一个表的...
标题"Hibernate一对一主键关联映射(双向关联)"中的"主键关联"指的是两个实体通过共享相同的主键来建立关联。"双向关联"则意味着在两个实体类中,都可以直接访问到对方的实例,即在实体A中有一个对实体B的引用,...
首先,一对一关联分为两种类型:单向关联和双向关联。单向关联意味着在一个实体类中存在对另一实体的引用,而另一实体类中没有相应的引用。唯一外键关联则表示在两个表之间通过一个外键字段建立一对一关系,这个外键...
9. Hibernate 一对一外键双向关联、主键双向关联、连接表双向关联、一对多外键双向关联、一对多连接表双向关联、多对多双向关联: 这些关联方式与单向关联类似,区别在于两个实体类都知道彼此的关联。在双向关联中...
在Hibernate中,一对一关系有多种实现方式,包括单向和双向关联,以及外键在主表还是从表等不同形式。 **压缩包子文件的文件名称列表:s2sh_relation01_one2one_uni_fk** 这个文件名暗示了这是一组基于Spring、...
本文将深入探讨如何使用Hibernate注解实现基于外键的一对多双向关联。我们将通过具体实例来解析这个主题,并结合源码分析其工作原理。 首先,我们要明白一对多关联意味着一个实体可以拥有多个关联的实体。在数据库...
本文主要探讨的是Hibernate中的两种关联关系:多对一单向关联和多对一双向关联。通过理解这两种关联方式,我们可以更好地设计和实现复杂的数据库模型。 首先,我们来看**多对一单向关联**。这种关联意味着一个实体...
在本案例中,我们将探讨如何在Hibernate中实现基于外键的双向一对一关联映射。 首先,我们来看一下双向一对一关联的基本概念。双向一对一关联意味着两个实体类A和B,它们之间存在一对一的关系,并且A能访问B,B也能...
本主题聚焦于“Hibernate双向一对一关联映射”的注解实现,这是一种高级的数据库设计模式,用于处理两个实体之间一对一的关系。 在Hibernate中,一对一关联映射分为单向和双向。单向一对一映射通常涉及一个实体持有...
综上所述,Hibernate提供了丰富的关联关系映射机制,包括一对一、一对多和多对多关联,每种关联又可以细分为单向和双向,以及基于主键和基于外键的不同实现方式。正确理解和选择合适的关联关系对于构建高效、可维护...