Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(3)

本文主要是介绍Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主控方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* */@Testpublic 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相同导致插入失败*/@Testpublic 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*/@Testpublic 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表*/@Testpublic void testMergeRole1(){RoleDAO roleDAO = new RoleDAO();Role role = roleDAO.getRole("111");		role.setName("被修改的角色");roleDAO.mergeRole(role);}/*** 修改role表以及级联关系但不修改org表(注:确保没有添加CascadeType.MERGE的支持)*/@Testpublic 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的支持)*/@Testpublic 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的,可以手动删除*/@Testpublic void testRemoveRole1(){RoleDAO roleDAO = new RoleDAO();Role role = (Role) roleDAO.getRole("111");  roleDAO.removeRole(role);}/*** 只删除关联关系,CascadeType.MERGE*/@Testpublic 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 双向ManyToMany 究极解决 新增-删除-修改-查询(3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819164

相关文章

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满