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的异常