浏览 2702 次
精华帖 (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的异常 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |