今天做了个测试,一共两张表,person和order,person是one方,order是many方。
person的hbm文件内容如下:
<hibernate-mapping package="cn.itcast.bean">
<class name="Person" table="person">
<id name="id" column="id" type="java.lang.Integer">
<generator class="native"/>
</id>
<property name="name" column="name" type="java.lang.String" not-null="true"/>
<set name="order" table="Order" outer-join="auto" cascade="delete" lazy="false">
<key column="person_id"/>
<one-to-many class="cn.itcast.bean.Order"/>
</set>
</class>
</hibernate-mapping>
order的hbm文件内容如下:
<hibernate-mapping package="cn.itcast.bean">
<class name="Order" table="orders">
<id name="id" column="id" type="java.lang.Integer">
<generator class="native"/>
</id>
<property name="personId" column="person_id" type="java.lang.Integer" not-null="true"/>
<property name="name" column="name" type="java.lang.String" not-null="true"/>
</class>
</hibernate-mapping>
删除时我是调用的personBean的一个delete方法去删除一条person记录的,然后我也想级联删除掉order表的记录,MyEclipse控制台打印出的语句如下(此次测试有3条order表的关联记录):
21:03:17,203 INFO [STDOUT] Hibernate: select person0_.id as id0_0_, person0_.name as name0_0_ from person person0_ where person0_.id=?
21:03:17,218 INFO [STDOUT] Hibernate: select order0_.person_id as person2_1_, order0_.id as id1_, order0_.id as id1_0_, order0_.person_id as person2_1_0_, order0_.name as name1_0_ from orders order0_ where order0_.person_id=?
21:03:17,218 INFO [STDOUT] Hibernate: update orders set person_id=null where person_id=?
21:03:17,218 INFO [STDOUT] Hibernate: delete from orders where id=?
21:03:17,218 INFO [STDOUT] Hibernate: delete from orders where id=?
21:03:17,218 INFO [STDOUT] Hibernate: delete from orders where id=?
21:03:17,218 INFO [STDOUT] Hibernate: delete from person where id=?
不解的问题如下:
1. 级联删除时,为什么hibernate要先把many方的关联的外键update成null而不是直接一条delete语句啊?该语句如下:update orders set person_id=null where person_id=?,因为我一开始建数据库时把外键设置成not-null,所以在执行到这里的时候控制台抛异常了,后来我把外键的not-null限制去掉才可以正确执行。
2. 为什么要把many方关联的记录先select出来再一条一条的delete呢?这个太影响效率了吧?还是我的hbm文件配置上有不合理的地方需要改进?
请大侠们指点!
分享到:
相关推荐
4. **级联查询示例**:例如,一个用户可以有多个订单,当删除用户时,如果设置了级联删除,那么相关的订单也会被一起删除。 5. **级联操作的优缺点**:优点是简化了代码,提高了开发效率;缺点是如果不合理使用,...
本文将深入探讨如何在Hibernate中处理Many-to-Many关系的级联保存、级联更新和级联删除。 一、Many-to-Many关系基础 在数据库设计中,Many-to-Many关系意味着两个实体之间存在多对多的关系。例如,学生可以选修多门...
2. 级联删除(Cascade Type.REMOVE) 当设置为`CascadeType.REMOVE`时,如果删除了父实体,与之关联的子实体也会被删除。这在处理一对多或者多对多关系时非常有用,可以确保相关的数据在数据库中得到一致性的清理。...
在文档中提到的场景下,我们来详细探讨Hibernate级联删除的原理和配置方法。 首先,我们要理解关系映射中的几个关键概念。在给出的例子中,有四个表:A、AA、B和BB,它们之间存在一对多(one-to-many)和一对一...
在Java持久化框架Hibernate中,级联操作是处理对象关系映射(ORM)时非常重要的一个特性。级联操作允许我们在对一个实体进行操作时,自动地影响与之相关的其他实体,无需显式地处理这些关联。在这个" Hibernate级联...
首先,级联操作在Hibernate中是一种配置,用于指定当主表中的实体发生变化时,是否以及如何更新或删除关联的从表实体。级联操作可以通过在映射文件或注解中进行设置。例如,如果t_card是主表,而t_person是从表,...
在Java的持久化框架Hibernate中,级联操作(Cascade)和反转(Inverse)是两个重要的概念,它们主要用于管理对象关系模型中的关联关系。在一对多的关系中,这些特性可以帮助简化数据操作,提高代码的可读性和维护性...
3.3、Hibernate级联关系(Av839011656,P3).mp4
在探讨Hibernate框架中的级联操作(cascade)与控制权反转(inverse)之前,我们需要先对Hibernate有一个基本的理解。Hibernate是一个开放源代码的对象关系映射(ORM)框架,它为Java应用提供了一种将对象模型映射到...
在 Hibernate 中,级联操作(Cascade)和反向属性(Inverse)是管理对象关系的重要概念,特别是在处理一对多(One-to-Many)或多对一(Many-to-One)关系时。 **级联操作(Cascade)** 级联操作定义了当主对象被...
在IT领域,尤其是在Java开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它允许开发者用面向对象的方式操作数据库。尽管随着Spring Data JPA等现代技术的崛起,Hibernate的使用频率有所下降,但其核心...
在Java持久化框架Hibernate中,一对多(One-to-Many)、多对一(Many-to-One)、级联(Cascading)、加载(Loading)和反转(Inversing)是关系映射的重要概念,它们对于理解如何在数据库和对象之间有效地管理关联至...
第七章_Hibernate_-_级联策略 第七章
总的来说,这个项目展示了如何使用Hibernate、Ajax和DWR来实现一个高效、用户友好的省市县三级级联选择功能。开发过程中涉及了ORM、MVC架构、数据库操作以及前端交互等多个方面,是学习和实践Web开发技能的好实例。
Ajax+struts+hibernate实现级联菜单 Ajax+struts+hibernate实现级联菜单 Ajax+struts+hibernate实现级联菜单
### Hibernate级联(Cascade)详解 #### 一、概述 Hibernate 是一款强大的对象关系映射 (ORM) 框架,它允许开发人员将 Java 对象模型映射到数据库表,从而极大地简化了数据访问层的开发工作。在 Hibernate 中,...
【标题】:“qt实现sqlite3级联删除demo” 在数据库管理中,级联删除是一种常见的功能,它允许在删除一个表中的记录时,自动删除与之相关联的其他表中的记录。在Qt环境下,结合SQLite3数据库,我们可以实现这一功能...
### SQL Server 创建触发器实现级联删除 在数据库管理中,触发器是一种特殊类型的存储过程,它被设计为响应特定的事件(如插入、更新或删除数据)而自动执行。本文将详细介绍如何在 SQL Server 中创建一个触发器来...
根据给定文件的信息,本文将围绕“用JDBC实现数据库的级联删除与更新”这一主题进行深入探讨,包括理解需求、设计思路、具体实现步骤以及相关代码示例。 ### 1. 需求理解 #### 1.1 业务场景 在本案例中,存在两个...