较为复杂的Hibernate 数据映射

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="all"
            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>

Address.hbm.xml 中:
       <id
            name="id"
            column="AddressId"
            type="string"
            unsaved-value="any">
           
<generator class="foreign">
                <param name="property">student</param>
            </generator>
        </id>

      <one-to-one name="student"
                    class="com.ivan.hibernate.Student"
                    constrained="true"/>

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);    
addr.setStudent(jake);

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 语句比更改前少,执行效率更高。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值