问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

hibernate注解映射 一对多对多 三表的关系,现有三张表A,B,C A和B是一对多的关系, B和C是多对多的关系

发布网友 发布时间:2022-05-06 16:24

我来回答

6个回答

懂视网 时间:2022-05-06 20:45

本次以一个示例方式进行演示,某个单位有多个部门,每个部门中又有很多不同的员工,在存储时需要建立一张员工表和一张部门表,存储全部的部门和员工信息,而这两张表中通过外键进行关联,从而能根据部门名称查询出该部门的所有员工,同时又能根据员工名称查

本次以一个示例方式进行演示,某个单位有多个部门,每个部门中又有很多不同的员工,在存储时需要建立一张员工表和一张部门表,存储全部的部门和员工信息,而这两张表中通过外键进行关联,从而能根据部门名称查询出该部门的所有员工,同时又能根据员工名称查询出他所在的部门。

不难看出部门与员工之间的关系是一对多的关系,相反,员工与部门之间的关系是多对一的关系。

在POJO类和映射文件自然想到使用Set集合表示一对多。

下面看一些部门类Department类

package entity;

import java.util.HashSet;
import java.util.Set;

public class Department {
	private Integer id;
	private String name;
	private Set employees = new HashSet();
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Set getEmployees() {
		return employees;
	}
	public void setEmployees(Set employees) {
		this.employees = employees;
	}
	
	
}

该类中使用Set集合存储员工信息,表示一个部门中有多个员工。

然后看员工类。

package entity;

public class Employee {
	private Integer id;
	private String name;
	private Department department;
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Department getDepartment() {
		return department;
	}
	public void setDepartment(Department department) {
		this.department = department;
	}
	
	
}

该类通过一个私有的Department类的属性,表示一个员工只能属于一个部门。

下面看一下他们的映射文件的配置。

首先看Department.hbm.xml




 
 
  
  
 
 
  
 
 
 
 
 
 
  
  
 
 

其中使用标签映射Department类中的Set集合属性,具体每隔属性在注释已经解释。通过表示两个关联类之间是一对多的关联关系。

然后看Employee.hbm.xml




 
 
  
  
 
 
  
 
 
 
 
 
 

这里通过属性指定员工类与部门类之间的映射关系是多对一。其中每个元素的含义在注释中已经介绍。

然后他们之间的映射关系已经搭建完毕,下面看一下测试类,使用JUtil进行测试。

package test;

import static org.junit.Assert.*;

import java.util.Iterator;
import java.util.Set;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;

import entity.Department;
import entity.Employee;
import factory.HibernateSessionFactory;

public class Test {

	private Session session = null;
	private Transaction tran = null;

	//保存对象
	@org.junit.Test
	public void test() {
		session = HibernateSessionFactory.getSession();
		tran = session.beginTransaction();
		try {
			//新建对象
			Department de = new Department();
			de.setId(3);
			de.setName("研发部");

			Employee e1 = new Employee();
			e1.setId(1);
			e1.setName("张三");

			Employee e2 = new Employee();
			e2.setId(2);
			e2.setName("李四");

			//建立关系映射
			de.getEmployees().add(e1);
			de.getEmployees().add(e2);
			e1.setDepartment(de);
			e2.setDepartment(de);

			//保存数据
			session.save(de);
			session.save(e1);
			session.save(e2);
			tran.commit();
		} catch (Exception e) {
			tran.rollback();
		}
	}

	//根据部门查询员工
	@org.junit.Test
	public void getDepartment() {
		session = HibernateSessionFactory.getSession();
		String hql = "FROM Department d where d.id = 2";
		Query query = session.createQuery(hql);
		Department de = (Department) query.uniqueResult();
		Set set = de.getEmployees();
		Iterator it = set.iterator();
		while (it.hasNext()) {
			Employee e = (Employee) it.next();
			System.out.println(e.getName());
		}
	}

	//根据员工查询部门
	@org.junit.Test
	public void getEmployee() {
		session = HibernateSessionFactory.getSession();
		String hql = "FROM Employee e where e.id=1";
		Query query = session.createQuery(hql);
		Employee e = (Employee) query.uniqueResult();
		System.out.println(e.getName() + "属于" + e.getDepartment().getName());

	}

	// 解除关联关系,相当于某一个员工离开原来部门,并不删除两个表中数据
	// 从员工方删除
	@org.junit.Test
	public void removeRelation() {
		session = HibernateSessionFactory.getSession();
		tran = session.beginTransaction();
		try {
			Department de = new Department();
			de.setId(1);
			de.setName("宣传部");
			session.save(de);
			Employee e = (Employee) session.get(Employee.class, 3);
			e.setDepartment(de);
			session.save(e);
			tran.commit();
		} catch (Exception e) {
			tran.rollback();
		}
	}

	// 删除员工方
	@org.junit.Test
	public void deleteEmployee() {
		session = HibernateSessionFactory.getSession();
		tran = session.beginTransaction();
		try {
			Employee e = (Employee) session.get(Employee.class, 4);
			session.delete(e);
			tran.commit();
		} catch (Exception e) {
			tran.rollback();
		}
	}

	// 删除部门
	@org.junit.Test
	public void deleteDepartment() {
		session = HibernateSessionFactory.getSession();
		tran = session.beginTransaction();
		try {
			Department de = (Department) session.get(Department.class, 1);
			/*
			 * 如果没有关联的员工,能删除
			 * 如果有关联的员工,且inverse属性为true,由于由不能维护关联,所以会直接执行删除,就会有异常
			 * 如果有关联的与昂,且inverse属性为false,由于可以维护关联关系,他就会先把关联的员工的外键设为null。在删除
			 */
			session.delete(de);
			tran.commit();
		} catch (Exception e) {
			tran.rollback();
		}
	}
}


热心网友 时间:2022-05-06 17:53

写一个临时方法
public class A{
private Set<B> b;
private Set<C> c;//这里我想通过A直接取C的集合,关系应该怎么写?
@Transient
public Set<C> getC(){
Set<C> cs = new HashSet<C>();
if (b!=null){
for(B o :b){
cs.add(b.getC());
}
}
return cs;
}
}追问非常感谢,给你加分!日后请多指教,还望不吝赐教

热心网友 时间:2022-05-06 19:11

<set name="b">
<key column=""/>
<one-to-many class=""/>
</set>

<set name="c">
<key column=""/>
<one-to-many class=""/>
</set>

把对应列和类路径填里面就好了追问a里面应该怎么写?

热心网友 时间:2022-05-06 20:46

不懂

热心网友 时间:2022-05-06 22:37

<one-to-many >

热心网友 时间:2022-05-07 00:45

你好!<set name="b">
<key column=""/>
<one-to-many class=""/>
</set>

<set name="c">
<key column=""/>
<one-to-many class=""/>
</set>

希望可以帮到你!
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
手机玻璃硬度是多少合适 ips屏幕硬度怎么样 手机硬度是什么意思? 2024年拼多多春节发货时间规定是什么?过年还要48小时发货吗? e元素e8100无线鼠标怎么使用 E元素X-8100靠谱吗?可以用几年? E元素X-8100现在有几种配色,哪一种配色好呢? E元素X-8100用的是什么色的轴,适合玩游戏吗? 浙c是哪个城市 浙c是哪里 榻榻米软包怎么安装 欧美MV下载 苏打水怎么清洗外阴 有一部电影外国片 如何用苏打水冲洗阴道 Trojan . Expense . Android . SexVideo . BA病毒有什么危害 用苏打水冲洗阴道怎么个冲洗法 自己怎么用苏打水冲洗阴道呢,就是怕冲洗不到位 怎么用苏打水清洗阴道, bilibili上有哪些欧美圈电影之类的剪辑 为什么交流电路中要用虚数J 数字信号处理DFT运算中-j乘以j是多少, -j乘以j,就是虚数相乘是多少 虚数是什么? j是虚数单位 那这个是怎么化简过去的? 数学:什么是虚数?详细! 虚数是什么,我想学虚数 为什么复数中-j等于1/j啊? 抱歉 是群发[抱拳]是什么意思啊 电子中j是虚数,怎么计算,知道的教教我 电力系统分析中虚部“j”怎么算? iPhone+11+Pro吃鸡陀螺仪为什么打不开 基金定投的好处有哪些? 基金定投好处 驱蚊扣的原理 驱蚊扣有用吗 驱蚊扣的副作用 驱蚊扣里装的是什么 驱蚊扣里面的液体有毒吗 驱蚊纽扣有用吗 小孩的驱蚊扣有用吗? https:&#47;&#47;wwn.lanzoul.com&#47;iBLcVzykkva密码 ccz8酷我音乐安卓链接↑↑↑↑如何 怎样往手机上面下载酷我音乐盒 酷我音乐唱的歌怎么下载 京东自营店发票显示:日用杂品*家装建材,怎么查明细 上海公司注册流程图详细的,全面的,及注册一家公司需要多少钱_百度知 ... 注册公司的流程是什么?公司和工厂有何区别? 买卖车位佣金谁付 内聘申请书怎么写 地下室、停车场及车位可否销售、抵押呢 县城开小诊所都需要办理什么手续 在什么单位办 千里共婵娟婵娟是什么 Hibernate一对多映射关系怎么在一的一端保存2个或多个多的一端的对象 中国银行星期六有上班吗?