较为复杂的 Hibernate 数据映射
2008-02-23 09:34:31来源:互联网 阅读 ()
原文请见: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 语句比更改前少,执行效率更高。
上一篇: 一年以来对Java的一些感想!!
下一篇: 如何區分==和 equals
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash