一。mapping
使用三个表,分别为TBL_OSU_PRODUCT_I、TBL_OSU_BUSINESSFUNCTION_I和TBL_OSU_PRODUCTBUSINESS_C,1和2为多对多关系,3为其中间表
1.TBL_OSU_PRODUCT_I
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.netqin.function.osuproduct.product.model.OsuProduct" table="TBL_OSU_PRODUCT_I" schema="OSU_WORK">
<id name="id" type="long">
<column name="PRDU_ID" precision="10" scale="0" />
<generator class="sequence">
<param name="sequence">SEQ_OSU_PRODUCT_I</param>
</generator>
</id>
<property name="prduName" type="string">
<column name="PRDU_NAME" length="200" not-null="true" />
</property>
<property name="prduDescription" type="string">
<column name="PRDU_DESCRIPTION" length="200" />
</property>
<set name="business" table="TBL_OSU_PRODUCTBUSINESS_C" lazy="false" inverse="false" cascade="save-update" schema="OSU_WORK">
<key column="PRBU_PRDUID_FK"/>
<many-to-many class="com.netqin.function.osuproduct.businessfunction.model.BusinessFunction" column="PRBU_BUFUID_FK"/>
</set>
</class>
</hibernate-mapping>
说明:只有1中做了关联配置。lazy="false" :加载1时级联加载2,方便页面使用(看需要使用)。inverse="false":控制权由1负责。
cascade="save-update" :级联关系为新增和修改,不能加上delete,否则会一并删除2中的记录。
2.TBL_OSU_BUSINESSFUNCTION_I
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.netqin.function.osuproduct.businessfunction.model.BusinessFunction" table="TBL_OSU_BUSINESSFUNCTION_I" schema="USERINFOV2">
<id name="bufuId" type="java.lang.String">
<column name="BUFU_ID" length="10" />
<generator class="uuid.hex" />
</id>
<property name="bufuBusiidFk" type="java.lang.String">
<column name="BUFU_BUSIID_FK" length="10" not-null="true" />
</property>
<property name="bufuName" type="java.lang.String">
<column name="BUFU_NAME" length="64" not-null="true" />
</property>
<property name="bufuType" type="java.lang.Long">
<column name="BUFU_TYPE" precision="4" scale="0" not-null="true" />
</property>
</class>
</hibernate-mapping>
说明:没有做关联
3.TBL_OSU_PRODUCTBUSINESS_C
没有映射文件,仅有两个字段,代表两个表的主键,分别为PRBU_PRDUID_FK和PRBU_BUFUID_FK,前者为1的主键,后者为2的主键
二。操作方法
1.新增
String[] businesses= request.getParameterValues("businesses");
if (businesses != null&& businesses.length > 0) {
for (int i = 0; i < businesses.length; i++) {
BusinessFunction bf = (BusinessFunction)dao.findById(BusinessFunction.class, businesses[i]);//根据主键从数据库中查询出另一方的对象
object.getBusiness().add(bf);//关联对象
}
}
dao.save(object);
2.修改
OsuProduct object_tem = this.findById(object.getId());//从数据库中查询出主表对象
object_tem.getBusiness().removeAll(object_tem.getBusiness());//清空原有级联对象
copyProject(object_tem, object);//其余属性复制,同many-to-one
String[] businesses= request.getParameterValues("businesses");
if (businesses != null&& businesses.length > 0) {
for (int i = 0; i < businesses.length; i++) {
BusinessFunction bf = (BusinessFunction)dao.findById(BusinessFunction.class, businesses[i]);
object_tem.getBusiness().add(bf);
}
}
dao.update(object_tem);
3.删除
删除主表即可
dao.delete(object);
分享到:
相关推荐
本文将深入探讨如何在Hibernate中处理Many-to-Many关系的级联保存、级联更新和级联删除。 一、Many-to-Many关系基础 在数据库设计中,Many-to-Many关系意味着两个实体之间存在多对多的关系。例如,学生可以选修多门...
"Hibernate one-to-many / many-to-one关系映射"是两个基本的关系类型,用于表示实体间的关联。在这个主题中,我们将深入探讨这两种关系映射的原理、配置和实际应用。 一、一对一(one-to-one)与一对多(one-to-...
### Hibernate Many-to-One (多对一) 及 Cascade (级联) #### 一、Many-to-One(多对一) 在数据库设计中,实体之间的关系主要包括一对一、一对多、多对多等几种类型。而在ORM(对象关系映射)框架Hibernate中,...
在Java的持久化框架Hibernate中,Many-to-Many映射是一种常见的关系模型,它用于表示两个实体类...通过以上介绍,你应该对Hibernate中的Many-to-Many映射注解有了更深入的理解,这将有助于你在Java持久化领域的实践。
在Hibernate中,`one-to-many`关系是常见的实体间关系之一,表示一个实体可以与多个其他实体相关联。本文将深入探讨`Hibernate one-to-many`注解的使用和实现细节。 ### 一、`@OneToMany`注解概述 `@OneToMany`...
"Hibernate many-to-many"指的是Hibernate中处理多对多关联关系的一种方式。多对多关系是两个实体类之间存在的一种复杂关联,比如学生和课程之间的关系,一个学生可以选修多门课程,一门课程也可以被多个学生选修。 ...
《深入理解Hibernate:第三解——Many-to-One关系映射实战》 在Java世界里,ORM(Object-Relational Mapping)框架的出现极大地简化了数据库与Java对象之间的交互,而Hibernate作为其中的佼佼者,更是备受开发者青睐...
<many-to-one name="childEntity" class="com.example.ChildEntity" cascade="all,delete-orphan" /> ``` 在这个例子中,父实体的`childEntity`属性将执行全部级联操作,包括添加、删除和更新,同时`delete-orphan`...
标题"Hibernate one to many(many to one) 配置"涉及到的是关系型数据库在Java中的持久化框架Hibernate中的两种关联映射关系:一对一(One-to-One)和多对一(Many-to-One)。在数据库设计中,这种关系很常见,例如...
</many-to-one> ``` 或者使用注解: ```java // 在TCard类中 @ManyToOne(cascade = {CascadeType.ALL}) @JoinColumn(name = "person_id") private TPerson person; ``` 在这个例子中,`cascade="all"`或`CascadeType...
外键映射是通过在主表映射文件中使用`one-to-one`元素,而从表映射文件中使用`many-to-one`元素来实现。主键映射则是两个实体类的主键相互关联,这需要在`one-to-one`节点上设置`constrained`属性为`true`,以表明...
<many-to-one name="department" class="com.example.Department" column="dept_id" /> ``` 接下来,我们将在Spring中配置Hibernate SessionFactory,并创建DAO接口及其实现。在添加部门时,可以同时添加员工到部门...
一、Hibernate级联(Cascade) 级联操作允许我们将对一个实体的更改自动应用到与之关联的其他实体。在一对多关系中,如果一个实体(父实体)与多个实体(子实体)关联,设置级联属性可以确保在处理父实体时,子实体...
在 Hibernate 中,级联操作(Cascade)和反向属性(Inverse)是管理对象关系的重要概念,特别是在处理一对多(One-to-Many)或多对一(Many-to-One)关系时。 **级联操作(Cascade)** 级联操作定义了当主对象被...
在Java持久化框架Hibernate中,一对多(One-to-Many)、多对一(Many-to-One)、级联(Cascading)、加载(Loading)和反转(Inversing)是关系映射的重要概念,它们对于理解如何在数据库和对象之间有效地管理关联至...
在给出的例子中,有四个表:A、AA、B和BB,它们之间存在一对多(one-to-many)和一对一(one-to-one)的关系。例如,A表与AA表是一对多关系,而A表与B表是一对一关系,B表与BB表也是一对多关系。 在Hibernate的映射...
在Java持久化框架Hibernate中,Many-to-Many(多对多)映射是一种常见的关联关系类型,用于表示两个实体类之间复杂的关系。在本场景中,我们探讨的是如何在Hibernate中配置Many-to-Many映射,并使用MySQL数据库来...
本文主要关注Hibernate中的一个核心概念——一对一(One-to-One)、一对多(One-to-Many)和多对一(Many-to-One)关联映射,特别是关于“一到多”单向和双向关联映射的配置心得。 首先,让我们了解“一到多”关联...
### Hibernate级联(Cascade)详解 #### 一、概述 Hibernate 是一款强大的对象关系映射 (ORM) 框架,它允许开发人员将 Java 对象模型映射到数据库表,从而极大地简化了数据访问层的开发工作。在 Hibernate 中,...
【标题】"hibernate-one-to-many-uni" 指的是在Hibernate框架下实现的一对多单向关联关系。Hibernate是Java开发中常用的持久化框架,它简化了数据库操作,使得开发者可以更加专注于业务逻辑而不是数据库交互。在这个...