较为复杂的 Hibernate 数据映射

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

原文请见:http://www-128.ibm.com/developerworks/cn/java/l-hibernate2/

这里我对它做了点点优化。Hibernate 在一对一的时候,只需要 Save 主对象就可以保存从对象;在一对多的时候,通过反转(inverse="ture")也只需要 Save 主对象来保存从对象;在多对多的时候,则主从对象都得保存。

针对如下图所示的对象持久化:

对于 Student-Address,可以通过保存 Student 来保存 Address;

对于 Student-Course,既要保存 Student,也要保存 Course;

对于 Classes-Student,可以通过保存 Classes 来保存 Student。

相应的我们需要在映射文件中指定主对象等:

Student.hbm.xml 中于三个对象的设置:

<set name="courses"

table="Student_Course_Link"

lazy="false"

inverse="true"

cascade="all"

sort="unsorted">

<key column="StudentId"/>

<many-to-many

class="com.ivan.hibernate.Course"

column="CourseId"

outer-join="auto"/>

</set>

<many-to-one

name="classes"

class="com.ivan.hibernate.Classes"

cascade="none"

outer-join="auto"

update="true"

insert="true"

column="ClassesId"/>

<one-to-one

name="address"

class="com.ivan.hibernate.Address"

cascade="none"

outer-join="auto"

constrained="false"/>

Classes.hbm.xml 中与 Student 的设定:

<set name="students"

table="Students"

lazy="false"

inverse="true"

cascade="all"

sort="unsorted">

<key column="ClassesId"/>

<one-to-many class="com.ivan.hibernate.Student"/>

</set>

Course.hbm.xml 中与 Student 的设定:

<set name="students"

table="Student_Course_Link"

lazy="false"

inverse="false"

cascade="all"

sort="unsorted">

<key column="CourseId"/>

<many-to-many class="com.ivan.hibernate.Student"

column="StudentId"

outer-join="auto"/>

</set>

Classes.java、Student.java、Course.java 文件中的属性是 Set 类型的,请先初始化 new HashSet()。

这样,原有的 TestServelet.java 中的

Student jake = new Student();

jake.setName("jake");

jake.setId("008");

Address addr=new Address();

addr.setCity("beijing");

addr.setState("bj");

addr.setStreet("tsinghua");

addr.setZip("100083");

addr.setId(jake.getId());

jake.setAddress(addr);

Set set=new HashSet();

set.add(jake);

Course course=new Course();

course.setId("218");

course.setName("computer_jsp");

course.setStudents(set);

Classes cl=new Classes();

cl.setId("238");

cl.setName("pro computer");

cl.setStudents(set);

jake.setClasses(cl);

session.save(addr);

session.save(cl);

session.save(course);

session.save(jake);

可以更改为:

Student jake = new Student();

jake.setName("jake");

jake.setId("008");

Address addr=new Address();

addr.setCity("beijing");

addr.setState("bj");

addr.setStreet("tsinghua");

addr.setZip("100083");

addr.setId(jake.getId());

jake.setAddress(addr);

Course course=new Course();

course.setId("218");

course.setName("computer_jsp");

course.getStudents().add(jake);

jake.getCourses().add(course);

Classes cl=new Classes();

cl.setId("238");

cl.setName("pro computer");

jake.setClasses(cl);

cl.getStudents().add(jake);

session.save(cl);

session.save(course);

通过设置 hibernate.cfg.xml 中的 <property name="show_sql">true</property> 可以看到更改后的执行的 SQL 语句比更改前少,执行效率更高。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航