`
sefcertyu
  • 浏览: 249987 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

jpa级联操作详解5-级联更新2(CascadeType.MERGE)

 
阅读更多

在上一讲中我们看到两次发出的sql语句是一样的,也就是说两种情况对数据库的操作是一样的,为什么会这样呢?

主要是由于,级联更新在实体是游离状态下才起作用现在依然使用上一讲的实体bean;

第一次在Garage.java 不添加CascadeType.MERGE注解

	@OneToMany(cascade={CascadeType.PERSIST},mappedBy="garage")
	public Set<Auto> getAutos() {
		return autos;
	}

重新编写单元测试方法

	@Test public void update() {
		EntityManagerFactory factory = Persistence.createEntityManagerFactory("jpa-hibernate");
		EntityManager em = factory.createEntityManager();
		em.getTransaction().begin();
		Garage garage = em.find(Garage.class, 1);
		em.clear(); //改为游离状态
		garage.setGaragenum("RoomTOP");
		
		em.merge(garage);
		em.getTransaction().commit();
		em.close();
		factory.close();
	}

 运行之后

观察发出的sql语句

Hibernate: select garage0_.gid as gid1_0_, garage0_.garagenum as garagenum1_0_ from Garage garage0_ where garage0_.gid=?
Hibernate: select garage0_.gid as gid1_0_, garage0_.garagenum as garagenum1_0_ from Garage garage0_ where garage0_.gid=?
Hibernate: update Garage set garagenum=? where gid=?

 (二)添加CascadeType.MERGE注解

 

	@OneToMany(cascade={CascadeType.PERSIST,CascadeType.MERGE},mappedBy="garage")
	public Set<Auto> getAutos() {
		return autos;
	}

 运行单元测试方法update()

观察发出的sql语句

Hibernate: select garage0_.gid as gid1_0_, garage0_.garagenum as garagenum1_0_ from Garage garage0_ where garage0_.gid=?
Hibernate: select garage0_.gid as gid1_1_, garage0_.garagenum as garagenum1_1_, autos1_.garageid as garageid3_, autos1_.autoId as autoId3_, autos1_.autoId as autoId0_0_, autos1_.autonum as autonum0_0_, autos1_.autotype as autotype0_0_, autos1_.garageid as garageid0_0_ from Garage garage0_ left outer join Auto autos1_ on garage0_.gid=autos1_.garageid where garage0_.gid=?
Hibernate: update Garage set garagenum=? where gid=?

 比较第一次和第二次发出的sql语句,第二次是做外连接

分享到:
评论

相关推荐

    10_JPA详解_JPA中的一对多双向关联与级联操作.zip

    本资料包"10_JPA详解_JPA中的一对多双向关联与级联操作.zip"聚焦于JPA中的一个重要概念——一对多双向关联及其级联操作。以下是对这一主题的详细阐述。 **一对多关联** 在关系数据库设计中,一对多关联是最常见的...

    JPA中的一对多双向关联与级联操作

    级联操作是JPA提供的一种特性,允许开发者指定当一个实体被持久化、更新、删除时,其关联的实体应该如何处理。这可以通过`CascadeType`枚举在`@OneToMany`注解中设置。例如,如果我们希望当用户被删除时,所有相关的...

    spring jpa操作数据库 级联数据 hibernate

    例如,`@OneToMany`和`@ManyToOne`用于表示一对多或多对一的关系,级联操作如`CascadeType.PERSIST`、`CascadeType.MERGE`等可以确保当一个实体被保存或更新时,与其关联的实体也会相应更新。这在处理关联数据时非常...

    10_传智播客JPA详解_JPA中的一对多双向关联与级联操作

    JPA提供了多种级联类型,如`CascadeType.PERSIST`、`CascadeType.MERGE`、`CascadeType.REMOVE`等。例如,如果设置为`CascadeType.ALL`,那么当保存一个班级实体时,它所关联的所有学生实体也会被自动保存;同样,...

    11_JPA详解_JPA中的一对多延迟加载与关系维护.zip

    `CascadeType.ALL`意味着对父实体进行的操作(如保存、更新、删除)会级联到所有子实体。`CascadeType.MERGE`则表示仅在合并父实体时更新子实体。开发者需要根据业务需求来选择合适的级联类型,以避免不必要的数据...

    实体Bean之间的级联关系

    实体Bean之间的级联关系是Java持久化框架如Hibernate或JPA中的一个重要概念,它涉及到对象关系映射(ORM)中的数据操作同步性。在数据库中,实体Bean通常代表表中的行,而实体间的级联关系则反映了表之间的关联。...

    jpa--9.单向多对一

    - 如果希望在删除或更新Employee时,也影响到关联的Department,可以使用`@ManyToOne(cascade = CascadeType.ALL)`,指定级联操作类型。 6. **性能优化**: - 在处理大量数据时,考虑使用`@BatchSize`注解优化...

    14_传智播客JPA详解_JPA中的多对多双向关联的各项关系操作

    3. ** Cascade操作**:`@ManyToMany`支持级联操作,如`CascadeType.PERSIST`、`CascadeType.MERGE`等,这使得在保存或更新主侧实体时,关联的次侧实体也会相应处理。 4. **Fetch策略**:默认情况下,JPA使用懒加载...

    hibernate常见异常针对于jpa

    2. **使用级联操作:** 在实体关联定义中使用`cascade`属性来自动处理这些操作。例如: ```java @OneToMany(mappedBy = "controlId", fetch = FetchType.LAZY, cascade = {CascadeType.ALL}) private List...

    传智播客JPA学习笔记.pdf

    在JPA中,一对多关系通过@OneToMany和@ManyToOne注解定义,级联操作如CascadeType.PERSIST、CascadeType.REMOVE允许在操作父对象时自动处理子对象的状态。 **11. JPA中的一对多延迟加载与关系维护(一对多关系:二...

    14_JPA详解_JPA中的多对多双向关联的各项关系操作.zip

    JPA的`CascadeType`可以设置为不同的值,比如`PERSIST`, `MERGE`, `REMOVE`等,以控制关联实体的生命周期。例如,如果希望当删除学生时,自动删除所有关联的课程,可以在`@ManyToMany`上添加`cascade = CascadeType....

    Hibernate注释大全收藏

    - `CascadeType.PERSIST`: 级联创建操作。 - `CascadeType.MERGE`: 级联合并操作。 - `CascadeType.REMOVE`: 级联删除操作。 - `CascadeType.REFRESH`: 级联刷新操作。 - `CascadeType.ALL`: 所有上述操作。 #### ...

    JPA笔记

    3. **级联操作(Cascading)**: 可以设置`CascadeType`来决定当父实体操作时,是否同步操作关联的子实体。 4. **查询语言(JPQL)**: 类似于SQL,但面向对象,可以编写更复杂的查询语句。 5. **实体图形(Graph)*...

    hibernate-jpa学习

    这些关联可以通过注解来定义,并且可以配置级联操作(如CascadeType.ALL),以简化数据操作。 查询方面,除了JPQL,Hibernate还提供了 Criteria 查询,这是一种更加面向对象的查询方式,允许使用API构建查询条件,...

    jpa_learn_01.zip

    2. **级联操作(Cascading)**:通过`@CascadeType`,可以设置一个操作(如删除)是否影响关联的实体。 3. **事务管理**:JPA支持声明式事务管理,通过`@Transactional`注解在方法级别定义事务边界。 4. **实体...

    hibernate课件

    常见的级联类型有:`CascadeType.ALL`、`CascadeType.PERSIST`、`CascadeType.MERGE`等。 6. **HQL与Criteria查询** HQL是Hibernate特有的面向对象的查询语言,类似于SQL,但更接近Java语法。Criteria查询则是通过...

    SpringData+jpa一对一与一对多

    cascade 属性用于配置级联操作,包括 ALL、PERSIST、MERGE、REMOVE 和 REFRESH 等取值。根据需求选择合适的级联操作。 在 School 和 Address 中,我们可以使用 @OneToOne(cascade = CascadeType.ALL) 来维护一对一...

    Hibernate 注解映射

    * cascade 属性:指定级联操作的行为,可以选择 CascadeType.PERSIST、MERGE、REMOVE、REFRESH 和 ALL。 * 在双向关联中,需要通过调用双方的 set 方法来建立关系。 Hibernate 注解映射提供了一种简单、灵活的方式...

    app-jpa-relationships

    `@CascadeType`定义了不同的级联策略,如PERSIST、MERGE、REMOVE等。 2. 懒加载(Lazy Loading) 默认情况下,JPA会进行EAGER加载,即加载父实体时会一同加载所有子实体。但这样可能导致性能问题。为优化,我们...

    ejb开发使用手册,非常适合初学者

    例如,`@OneToOne`可以表示一对一的关系,并且可以设置`cascade`属性来控制级联操作,如`CascadeType.ALL`表示所有操作都会级联到关联的实体。 `persistence.xml`是EJB持久层配置文件,它定义了数据源、实体类、...

Global site tag (gtag.js) - Google Analytics