[align=center]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>[/align]
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的异常
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>[/align]
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的异常
本文详细介绍了Hibernate框架中fetch、lazy、inverse及cascade属性的作用及其配置方式。通过具体实例展示了如何利用这些属性实现父表与子表之间的级联查询、级联更新与级联删除等功能。同时,还讨论了不同配置下可能出现的问题及解决方法。
140

被折叠的 条评论
为什么被折叠?



