1.2 一对多 即两个表通过外键进行关联,一个部门,多个员工;一个学校,多个学生;这里的两个表通过外键关联
public class Department {
private int deptid;
private String dname;
private String location;
private Set<Employee> employees=new HashSet<Employee>(); //这里是一个集合 一个部门有多个 员工 即"多"
}
public class Employee {
private int empid;
private String ename;
private Department department; //而对每个员工来说只有一个部门 即 "一"
}
我们先按我们的思路想下配置文件 有一个Department对应{Employee..}也就是many 个Employee 对应一个
Department 并且有many个外键
<hibernate-mapping
package="com.bjsxt.po">
<class name="Employee" table="t_employee" >
<id name="empid">
<generator class="native"></generator>
</id>
<property name="ename"></property>
<many-to-one name="department" class="Department" cascade="all" >
<column name="dept_id"></column> <!-- 这个就是我们前面说到的多个外键--!>
</many-to-one>
</class>
</hibernate-mapping>
而Department类中不是有一个set 的集合吗 所以用到set
<hibernate-mapping package="com.bjsxt.po">
<class name="Department" table="t_department" >
<id name="deptid">
<generator class="native"></generator>
</id>
<property name="dname"></property>
<property name="location"></property>
<set name="employees" cascade="save-update" inverse="false" >
<key>
<column name="dept_id"></column> <!-- 对应employee中的一个列 --!>
</key>
<one-to-many class="Employee" />
</set>
</class>
</hibernate-mapping>
其中cascade 属性和inverse 属性比较重要
cascade 属性是级联的操作,比如我们增加一个员工时同时对该员工的部门设置了值.如果数据库中没有记录.则
强大的Hibernate 会为我们创建表,并添加记录并建立关系。当然这些只是我们上面配置的文件的作用.
cascase = all 进行任何操作时都级联
save-update 保存和更新时
delete 删除时级联
all-delete-orpnan 当被关联对象失去宿主时,将其删除 也就是如果我们把部门删除了,那么员工自然就没有家可回了,会被一并删除 特别注意如果此属性不设置,则会报错
inverse 属性 =false =true 表示由哪一方维护外键的值 false是双方都可以维护,true是有多方维护 .true效率高
最后,终于要说多对多的情况了 首先我们应该知道,多对多就会产生中间表,而中间表肯定有两个表的字段
1.n
public class Student2 {
private int id;
private String name;
private Set courses=new HashSet(); //这里是一个set的集合了, 学生可以有多门课程
}
public class Course {
private Long id;
private String name;
private Set students =new HashSet(); //课程也可以被多个同学选修
}
这里我们假设没有hibernate 帮我们的情况下,我们应该自己建立一个中间表 student_course
表中自然有student_id,course_id 如果我们这样想的话。那么配置文件一看就明白
<hibernate-mapping package="com.bjsxt.po">
<class name="Student2" table="t_student2" lazy="true">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"/>
<!-- set 出现了,表为stu_course 即为中间表--!>
<set name="courses" table="stu_course" cascade="save-update">
<key column="stuId" /> <!-- key 对应当前表的外键 --!>
<many-to-many class="Course" column="courseId" />
</set>
</class>
</hibernate-mapping>
此时我们应该猜想Course.hbm.xml应该和这个一样,只是一些小小的差别
<hibernate-mapping package="com.bjsxt.po">
<class name="Course" table="t_course" lazy="true">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"/>
<set name="students" table="stu_course" cascade="save-update">
<key column="courseId" /> //t_sourse的外键
<many-to-many class="Student2" column="stuId" />
</set>
</class>
</hibernate-mapping>
基础上一些大的我们已经配置完了。当然这些都可以在网上查到。但最少我们应该知道怎么配。
分享到:
相关推荐
自动生成hibernate映射文件和实体类
关于hibernate映射和查询,使用MySQL,适合初学者的练习
hibernate映射枚举类型,hibernate如何映射枚举类型
build.xml 手写自动生成Hibernate映射文件和配置文件源代码
用来生成hibernate映射文件.从而实现不需手动写入。。。很实用的东东哦。。
根据实体类生成简单的Hibernate映射文件,对不用Myeclipse的童鞋还是有用
常用 Hibernate 映射配置说明.doc
myeclipse自动生成hibernate映射文件
Hibernate映射解析 七种映射关系
用Hibernate映射继承关系
Myeclipse生成Hibernate映射文件
hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,hibernate,包含4个说明文档,分别详细解说了hibernate关联映射的...
Hibernate映射配置实例大全:详细总结了Hibernate的各种映射配置的方法,并逐一举例
用MyEclipse自动生成hibernate映射文件和实体类
Hibernate映射集合属性List,用于映射集合属性 List Hibernate 自动生成表 不需sql
hibernate 映射关系学习入门 多对多实体映射 源码
hibernate 映射关系 小结
注:为节省空间,程序中需要的jar包,均在HibernateManytoManyMapCascadingSave.zip\HibernateManytoManyMapCascadingSave\lib\ <br>Hibernate 多对多实体映射实例 <br>学习Hibernate 实体映射的映射的好帮手...
Hibernate映射配置详解