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

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

       近日拿起好久没碰的JAVA重新看了看,发现变化还真是大。在看Hiberhate时,发现他的ManyToMany用起来不是很方便,到网上一搜发现很多人都并没有完全了解这个关联关系的用法,为了造福人类,干脆我来个用例大全算了。

 

       在使用Hiberhate的关联映射时,不管你是双向还是单向,都是有主控方的,主控方的操作会自动的影响关联关系(中间表),对于双向多对多来说,主控方的操作则会自动的影响中间表,如果需要影响到被控方表内的数据,则需要进行CascadeType配置。

 

       但是当你在被控方操作数据时,被控方并不能影响到关联关系(中间表),如果要修改关联关系则需要配置CascadeType属性,同时配置了该属性也会影响到主控方表内的数据。

 

例子:

       假设我们要设计一个角色与组织机构对应的维护功能,对应表结构如下:

             组织机构表:org                                  角色表:role                                           中间表:org_role

             id,name,description                     id,name,parentId,description           orgId,roleId

 

       通常在此类功能中,角色和机构都是单独添加,但是在添加和维护的过程中需要同步二者的关联关系。

 

       实体类及annotation配置,注意红色字体,代码中CascadeType.PERSIST是为了演示而特地加入,实际应用中基本不用设置该选项,只需设置CascadeType.MERGE便可

org:

package org.taomujian.model;import java.util.ArrayList;
import java.util.List;import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;
import javax.persistence.Table;@Entity
@Table(name="org")
public class Org {private String id ;private String name;private String description;private List<Role> roleList = new ArrayList<Role>();@Idpublic String getId() {return id;}public void setId(String id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getDescription() {return description;}public void setDescription(String description) {this.description = description;}//	@ManyToMany(mappedBy="orgList",cascade={CascadeType.ALL},fetch=FetchType.EAGER)
	@ManyToMany(mappedBy="orgList",fetch=FetchType.EAGER,cascade={CascadeType.MERGE})public List<Role> getRoleList() {return roleList;}public void setRoleList(List<Role> roleList) {this.roleList = roleList;}@Overridepublic boolean equals(Object obj) {boolean flag = false;if(!(obj instanceof Org)){flag = false;}else {Org org = (Org)obj;if(org.getId().equals(this.getId())){flag = true;}}return flag;}@Overridepublic int hashCode() {int result = id.hashCode(); result = result+(int)'f';return result;}}

 

role:

package org.taomujian.model;import java.util.ArrayList;
import java.util.List;import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Table;@Entity
@Table(name="role")
public class Role {private String id;private String name;	private String parentId;private String description;	private List<Org> orgList = new ArrayList<Org>();public Role(){}public Role(String id, String name, String parentId, String discription) {this.id = id;this.name = name;this.parentId = parentId;this.description = discription;}@Idpublic String getId() {return id;}public void setId(String id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getParentId() {return parentId;}public void setParentId(String parentId) {this.parentId = parentId;}public String getDescription() {return description;}public void setDescription(String description) {this.description = description;}//	@ManyToMany(cascade={CascadeType.ALL})@ManyToMany(fetch=FetchType.EAGER,cascade={CascadeType.MERGE,CascadeType.PERSIST})@JoinTable(name="org_role",joinColumns={@JoinColumn(name="roleId",referencedColumnName="id")},inverseJoinColumns={@JoinColumn(name="orgId",referencedColumnName="id")})
	public List<Org> getOrgList() {return orgList;}public void setOrgList(List<Org> orgList) {this.orgList = orgList;}//重写该方法,以辨别是否是同一条数据	@Overridepublic boolean equals(Object obj) {boolean flag = false;if(!(obj instanceof Org)){flag = false;}else {Org org = (Org)obj;if(org.getId().equals(this.getId())){flag = true;}}return flag;}@Overridepublic int hashCode() {int result = id.hashCode(); result = result+(int)'f';return result;}
}

 在hibernate.cfg.xml增加实体类的配置

        <mapping class="org.taomujian.model.Org"/>
        <mapping class="org.taomujian.model.Role"/>

 

这篇关于Hibernate 双向ManyToMany 究极解决 新增-删除-修改-查询(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

csu1329(双向链表)

题意:给n个盒子,编号为1到n,四个操作:1、将x盒子移到y的左边;2、将x盒子移到y的右边;3、交换x和y盒子的位置;4、将所有的盒子反过来放。 思路分析:用双向链表解决。每个操作的时间复杂度为O(1),用数组来模拟链表,下面的代码是参考刘老师的标程写的。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

ural 1026. Questions and Answers 查询

1026. Questions and Answers Time limit: 2.0 second Memory limit: 64 MB Background The database of the Pentagon contains a top-secret information. We don’t know what the information is — you

Mybatis中的like查询

<if test="templateName != null and templateName != ''">AND template_name LIKE CONCAT('%',#{templateName,jdbcType=VARCHAR},'%')</if>

速盾高防cdn是怎么解决网站攻击的?

速盾高防CDN是一种基于云计算技术的网络安全解决方案,可以有效地保护网站免受各种网络攻击的威胁。它通过在全球多个节点部署服务器,将网站内容缓存到这些服务器上,并通过智能路由技术将用户的请求引导到最近的服务器上,以提供更快的访问速度和更好的网络性能。 速盾高防CDN主要采用以下几种方式来解决网站攻击: 分布式拒绝服务攻击(DDoS)防护:DDoS攻击是一种常见的网络攻击手段,攻击者通过向目标网