主控方Role控制的增删改查:
说明都在代码注释里了,一起看方便。
package com.taomujian.dao;
import java.util.List;
import org.junit.Test;
import org.taomujian.dao.OrgDAO;
import org.taomujian.dao.RoleDAO;
import org.taomujian.model.Org;
import org.taomujian.model.Role;
public class RoleDAOTest {
/**
* 完整的插入role和org及其级联关系,需要配置CascadeType.PERSIST
*
*/
@Test
public void testSaveRole1() {
RoleDAO roleDAO = new RoleDAO();
Org org = new Org();
org.setId("dd1");
org.setName("我是被role添加的a!");
Role role = new Role();
role.setId("111");
role.setName("我是自己role自己主动添加的a!");
role.getOrgList().add(org);
org.getRoleList().add(role);
roleDAO.saveRole(role);
}
/**
* 新增role数据,并添加和已经存在的org对应的级联关系到中间表中
* 注:不能配置CascadeType.PERSIST,否则hibernate会插入一条记录
* 到org表中,但是因为ID相同导致插入失败
*/
@Test
public void testSaveRole2(){
RoleDAO roleDAO = new RoleDAO();
Org org = new Org();
org.setId("dd1");
Role role = new Role();
role.setId("111");
role.setName("角色");
role.getOrgList().add(org);
org.getRoleList().add(role);
roleDAO.saveRole(role);
}
/**
* 只插入角色
*/
@Test
public void testSaveRole3(){
RoleDAO roleDAO = new RoleDAO();
Role role = new Role();
role.setId("1112");
role.setName("角色");
roleDAO.saveRole(role);
}
/**
* 只增加关联关系到中间表中,需要添加CascadeType.MERGE
*/
@Test
public void testSaveRole4(){
RoleDAO roleDAO = new RoleDAO();
OrgDAO orgDAO = new OrgDAO();
Role role = roleDAO.getRole("111");
Org org = orgDAO.getOrg("dd1");
org.getRoleList().add(role);
role.getOrgList().add(org);
roleDAO.mergeRole(role);
}
/**
* 只修改role表
*/
@Test
public void testMergeRole1(){
RoleDAO roleDAO = new RoleDAO();
Role role = roleDAO.getRole("111");
role.setName("被修改的角色");
roleDAO.mergeRole(role);
}
/**
* 修改role表以及级联关系但不修改org表(注:确保没有添加CascadeType.MERGE的支持)
*/
@Test
public void testMergeRole2(){
RoleDAO roleDAO = new RoleDAO();
Role role = roleDAO.getRole("111");
role.setName("被修改的角色");
//该org记录在数据库表中已经存在
Org org = new Org();
org.setId("dd2");
if(role.getOrgList().size()==0||!role.getOrgList().contains(org));{
role.getOrgList().add(org);
}
//hibernate发现关联关系变化后,会先删除org_role表中相关的关联数据,然后重新插入关联关系数据
roleDAO.mergeRole(role);
}
/**
* 修改role表以及级联关系而且修改org表(注:需要增加CascadeType.MERGE的支持)
*/
@Test
public void testMergeRole3(){
RoleDAO roleDAO = new RoleDAO();
Role role = roleDAO.getRole("111");
role.setName("被修改的角色");
//修改原来存在于数据库中的数据
for(Org org : role.getOrgList()){
org.setName("我们都被role给修理了!");
}
//该org记录在数据库表中如果存在则修改,如果不存在则新增
Org org = new Org();
org.setId("dd3");
org.setName("我被role修理了!");
if(!role.getOrgList().contains(org));{
role.getOrgList().add(org);
}
//hibernate发现关联关系变化后,会先删除org_role表中相关的关联数据,然后重新插入关联关系数据
roleDAO.mergeRole(role);
}
/**
* 删除角色:除了会删除role表中的数据也会删除关联表org_role中的数据,但不会删除org表中的数据
* 不会产生脏数据
* (注:hibernate 没有提供REMOVE方法,所以无法对删除功能进行单独的配置,
* 除非将cascade配置为ALL,但是这样有可能能会带来很多不想要的结果)
*
* 注:在不配置cascade的情况下希望删除role的同时删除org的,可以手动删除
*/
@Test
public void testRemoveRole1(){
RoleDAO roleDAO = new RoleDAO();
Role role = (Role) roleDAO.getRole("111");
roleDAO.removeRole(role);
}
/**
* 只删除关联关系,CascadeType.MERGE
*/
@Test
public void testRemoveRole2(){
RoleDAO roleDAO = new RoleDAO();
Role role = roleDAO.getRole("111");
List<Org> orgList = role.getOrgList();
for (int i=0;i<role.getOrgList().size();i++) {
Org org = orgList.get(i);
// 下面两句就是关键代码了 多对多的所有操作都必须同时操作两端的表,保存 更新 删除等都是如此
org.getRoleList().remove(role); // 删除组织机构表对角色的引用
role.getOrgList().remove(org);// 删除角色表对组织机构表的引用
}
roleDAO.mergeRole(role);
}
}
分享到:
相关推荐
本教程将深入探讨如何使用Hibernate实现多表之间的双向关联,包括单-多、多-单、多-多关系。 **一、单-多关系** 在数据库设计中,单-多关系指的是一个实体可以与多个其他实体相关联。例如,一个学生可以属于多个...
在SSH(Spring、Struts、Hibernate)框架中,Hibernate作为持久层的解决方案,极大地简化了数据库操作的复杂性。SSH框架的组合使得企业级应用开发更加高效和便捷。 "hibernate-release-5.2.10" 是Hibernate的一个...
3. 插入和查询数据: - 在添加数据时,需要同时操作两个实体,确保关联关系的正确性。例如,当添加一个学生到课程时,也要将该课程添加到学生的选修课程列表中。 - 查询时,可以通过导航属性直接获取相关联的实体...
本文将深入探讨如何在Hibernate中实现多对多(ManyToMany)的关系映射,以及相关的重要概念和技术细节。 在数据库设计中,多对多关系是最常见的一种关联类型,例如,一个学生可以选修多门课程,一门课程也可以被多...
在IT行业中,Hibernate是一个非常重要的Java持久化框架,它简化了数据库操作,使得开发者可以更加专注于业务逻辑,而不是底层的数据存取。这篇博客"Hibernate学习一--注解方式自动建表"主要探讨了如何使用...
为了查询多对多关系,可以使用HQL(Hibernate Query Language)或者Criteria API。例如,要获取一个学生的所有课程: ```java String hql = "from Student s where s.id = :studentId"; Query<Student> query = ...
Session则代表了一个数据库连接,是执行数据库操作的接口,它可以用来保存、更新、删除对象,以及执行HQL(Hibernate查询语言)和SQL。 三、持久化对象与实体类 在Hibernate中,Java类被称为实体类,它们代表数据库...
本篇将详细阐述Hibernate中的对象三状态、一对一(OneToOne)、一对多(OneToMany)以及多对多(ManyToMany)关系映射。 一、Hibernate对象三状态 1. 游离态(Detached):对象在应用程序中创建,但尚未与Session...
### Hibernate Annotations 3.5.0-Final:深入解析与应用 #### 一、概述 在对象关系映射(ORM)领域中,Hibernate 是一款非常成熟的框架,它提供了丰富的功能来帮助开发者处理复杂的数据库交互问题。随着 Java ...
《深入理解Hibernate注解》 Hibernate作为Java领域中的一...综上,Hibernate注解为Java开发人员提供了更便捷、更直观的ORM解决方案。通过熟练掌握并合理运用这些注解,开发者可以更好地驾驭数据库操作,提高开发效率。
4. **Criteria查询**:除了传统的HQL(Hibernate Query Language)查询,3.6.6版本还提供了Criteria API,这是一种更加面向对象的查询方式,可以动态构建查询条件,增强了代码的可读性和灵活性。 5. **实体生命周期...
Hibernate Annotations是Hibernate 3.x系列引入的新特性,它允许开发者在Java实体类上直接使用注解来定义对象关系映射信息,替代了传统的Hibernate XML配置文件。这种注解方式提高了开发效率,减少了配置文件的维护...
3. **查询语言(JPQL,Java Persistence Query Language)**:类似于SQL,但面向对象,用于从数据库检索实体。 4. **Criteria API**:提供构建动态查询的能力,比JPQL更灵活,可以避免SQL注入问题。 5. **事务...
- **Session**:是Hibernate中的工作单元,负责对象的持久化操作,如保存、更新、删除和查询。 - **SessionFactory**:用于创建Session对象,它是线程安全的,应用程序中通常只需要一个SessionFactory实例。 - **...
在Java的持久化框架Hibernate中,Many-to-Many关系是一种常见的数据模型,它表示一个实体可以与多个其他实体之间存在关联,反之亦然。这篇博客文章可能会深入探讨如何在Hibernate中处理这种多对多的关系,并可能涉及...
【标题】"hibernate-entitymanager-3.4.0.GA" 是一个与Java持久化框架Hibernate Entity Manager相关的库,这个版本号表明它是2009年左右发布的一个稳定版本。Hibernate Entity Manager是JPA(Java Persistence API)...
【标题】"Hibernate之第2解之-hibernate_demo_1_annotation"主要涵盖了使用Hibernate框架进行对象关系映射(ORM)的实践,特别是基于注解的方式。在这个教程中,我们将深入探讨如何利用Java注解来配置Hibernate实体...
3. 添加、删除关联的实现: 在单向维护的多对多关联中,所有的关联添加和删除操作都需要在`User`实体上进行。例如,添加一个角色到用户: ```java User user = userRepository.findById(userId).orElseThrow(); ...
4. **HQL和 Criteria 查询:** Hibernate支持面向对象的查询语言HQL,以及Criteria API,提供了更灵活的查询方式,不同于传统的SQL。 5. **缓存机制:** Hibernate提供了第一级缓存(Session级别的)和第二级缓存...
Hibernate 是一个广泛使用的Java语言的对象关系映射(ORM)框架,它允许开发者将数据库操作转换为面向对象的方式,简化了Java应用的数据库交互。Hibernate Annotations是Hibernate框架的一部分,提供了注解方式来...