hibernate入门(六):一对多

本文详细阐述了在数据库设计中如何通过一对多关系映射实现部门与员工之间的关联,包括Java实体类的修改、配置文件的调整以及测试类的编写。通过实例展示了映射操作的步骤和效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2.一对多关系映射:

上面提到的多个员工对应于一个部门,是多对一的关系,如果一个部门有多个员工,则用“一对多”的关系来表示这个关系,现接上例继续,以实现一对多的关系映射。具体操作步骤如下:

>>步骤一,在Department.java中增加如下内容:private Set<Employee> emps; 及相应的get/set方法。

>>步骤二,修改Department的实体配置文件。在class元素下增加如下内容:

<set name="emps">

<key column="depart_id"></key>

<one-to-many class="Employee"/>

</set>

说明: <set>元素同样是指定一个属性,只不过是指定一个特殊的属性,key中的column为映射文件的外键,这里是指Employee.java相关的实体对象的外键。<one-to-many class="Employee"/>中的class表示关联的外键为Employee对象,也即Set中泛型机制指定的类。

>>步骤三,修改主配置文件,关联上面的实体配置文件。

>>步骤四,编写测试类,OneToManyTest.java 内容(省略导入的包)如下:

package com.asm.hibernate.test;   
public class OneToManyTest {
public static void main(String[] args) {
add();
query(1);
}
static Department query(int departId) {
Session s = null;
try {
s = HibernateUtil.getSession();
Department depart = (Department) s.get(Department.class, departId);
System.out.println("employee size:" + depart.getEmps().size());
return depart;
} finally {
if (s != null)
s.close();
}
}
static void add() {
Session s = null;
Transaction tx = null;
try {
Department depart = new Department();
depart.setName("departName");

Employee emp1 = new Employee();
emp1.setName("empName1");
emp1.setDepart(depart);
Employee emp2 = new Employee();
emp2.setName("empName2");
emp2.setDepart(depart);

// Set<Employee> emps = new HashSet<Employee>();
// emps.add(emp1);
// emps.add(emp2);
// depart.setEmps(emps);

s = HibernateUtil.getSession();
tx = s.beginTransaction();
s.save(depart);
s.save(emp1);
s.save(emp2);
tx.commit();
} finally {
if (s != null)
s.close();
}
}
}

说明:此类比较简单,增加两个员工信息,然后查出,同样可以体现出这种查询的方便,可以查看控制台,发现实质也是进行了两次查询操作。特别注意,上面注释掉的内容,思考怎样实现映射?如果加上注释掉的内容将会在控制台增加两条更新操作(注意更新的内容)。实际上注释掉的内容和已有内容建立了两种关联:“多对一”、“一对多”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值