最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Hibernate关联关系映射之一对多关联关系

来源:动视网 责编:小采 时间:2020-11-09 14:44:53
文档

Hibernate关联关系映射之一对多关联关系

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


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

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

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

在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();
	}
	}
}


文档

Hibernate关联关系映射之一对多关联关系

Hibernate关联关系映射之一对多关联关系:本次以一个示例方式进行演示,某个单位有多个部门,每个部门中又有很多不同的员工,在存储时需要建立一张员工表和一张部门表,存储全部的部门和员工信息,而这两张表中通过外键进行关联,从而能根据部门名称查询出该部门的所有员工,同时又能根据员工名称查
推荐度:
标签: 一个 映射 关联
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top