论坛首页 Java企业应用论坛

Hibernate 中的 fetch , lazy , inverse 和 cascade

浏览 2701 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-02-18   最后修改:2009-07-23
1.fetch 和 lazy 主要用于级联查询(select) 而 inverse和cascade主要用于级联增、加删、除修改(sava-update,delete)
2.想要删除父表中的记录,但希望子表中记录的外键引用值设为null的情况:
   父表的映射文件应该如下配置:
        <set name="emps" inverse="false" cascade="all">
            <key>
                <column name="DEPTNO" precision="2" scale="0" />
            </key>
            <one-to-many class="com.sino.hibernate.Emp" />
        </set>
    inverse="false"是必须的,cascade可有可无,并且子表的映射文件中inverse没必要设置,cascade也可以不设置,如果设置就设置成为cascade="none"或者cascade="sava-update"
<many-to-one name="dept" class="com.sino.hibernate.Dept" fetch="select" cascade="save-update">
            <column name="DEPTNO" precision="2" scale="0" />
        </many-to-one>


3.关于级联查找
  对子表的持久化类进行查找的时候,会一起把子表持久化类中的父表持久化类的对象一起查询出来,在页面中可以直接取值的情况:
    要把父表的映射文件中设置 lazy 属性如下:
<class name="com.sino.hibernate.Emp" table="EMP" schema="SCOTT" lazy="false">
这样就可以直接在页面中取值 (类似于这样的取值 client.cmanager.id)
如果没有设置 lazy="false" 则会抛出异常
javax.servlet.ServletException: Exception thrown by getter for property cmanager.realName of bean cl
在Action中取值的话就会抛出
could not initialize proxy - the owning Session was closed的异常
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics