J2EE系列之Hibernate4学习笔记(十二)--Hibernate继承关系映射(每个类对应一个表)

来源:互联网 发布:南京网络问政回复时间 编辑:程序博客网 时间:2024/05/19 12:37

上一篇博客中将讲的是根类成为数据库中的表,而子类不保存到数据库。这一讲讲一下每个类都成为数据库中的数据表。

1.在上一个工程上面修改。

2.新建照片类Image3:

package com.test.model;public class Image3 {private int id;private String imageName;private Student3 student;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getImageName() {return imageName;}public void setImageName(String imageName) {this.imageName = imageName;}public Student3 getStudent() {return student;}public void setStudent(Student3 student) {this.student = student;}}

3.新建生活照类:

package com.test.model;public class LifeImage3 extends Image3{}
4.新建工作照类:

package com.test.model;public class WorkImage3 extends Image3{}

5.新建学生类Student3:

package com.test.model;import java.util.Set;public class Student3 {private int id;private String name;private Set<Image3> images;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Set<Image3> getImages() {return images;}public void setImages(Set<Image3> images) {this.images = images;}}

6.写学生类映射文件:

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping package="com.test.model"><class name="Student3" table="t_student3"><id name="id" column="stuId"><generator class="native"></generator></id><property name="name" column="stuName"></property><set name="images"><key column="stuId"></key><one-to-many class="com.test.model.Image3"/></set></class></hibernate-mapping>

这里stuId就是主键又是外键。

7.写照片类映射文件:

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping package="com.test.model"><class name="Image3" table="t_image3"><id name="id" column="imageId"><generator class="native"></generator></id><property name="imageName" column="imageName"></property><many-to-one name="student" column="stuId" class="com.test.model.Student3"></many-to-one><joined-subclass name="com.test.model.LifeImage3" table="t_lifeImage3"><key column="lifeImageId"></key></joined-subclass><joined-subclass name="com.test.model.WorkImage3" table="t_workImage3"><key column="workImageId"></key></joined-subclass></class></hibernate-mapping>

这里通过<joined-subclass>标签指定了子类LifeImage3对应的数据表为t_lifeImage3,并且表t_lifeImage3的主键lifeImageId为t_image3表的外键,由t_image3的主键imageId对应lifeImageId。

8.写测试方法:

@Testpublic void testGetAllImages3(){}

运行这个测试方法,看一下生成的数据库表的结构:


给各个表中添加测试数据:

                

修改测试方法:

@Testpublic void testGetAllImages3(){Student3 student3 = (Student3) session.get(Student3.class, 1);Set<Image3> images = student3.getImages();Iterator it = images.iterator();while(it.hasNext()){Image3 image = (Image3) it.next();System.out.println(image.getImageName());}}

运行测试方法:


这里也是通过Student类取到了数据库中照片类信息。




阅读全文
0 0
原创粉丝点击