【Hibernate框架开发之七】Annotation各种关系CRUD增删改查&集合映射&继承映射

简介:

 首先对于Annotation中CRUD的C(Create)操作:------------------------

假设 :   User (MonyToOne)       Group

OK,那么有如下 Junit Code:

 

 
 
  1. Configuration cfg = new AnnotationConfiguration(); 
  2. SessionFactory sf = cfg.configure().buildSessionFactory(); 
  3. Session ss = sf.getCurrentSession(); 
  4.  
  5. Group group = new Group(); 
  6. group.setName("Group1"); 
  7.  
  8. User user = new User(); 
  9. user.setName("User_Himi");//备注1(在内存中建议关系) 
  10. user.setGroup(group); 
  11.  
  12. ss.beginTransaction(); 
  13.  
  14. //ss.save(group);//备注2 
  15. ss.save(user); 
  16.  
  17. ss.getTransaction().commit(); 
  18. sf.close(); 

备注1:如果想让两个在数据库中建立关联,那么在内存中就需要让其设置关联。

备注2:如果这里备注2行代码注视掉,是会报错的。因为Hibernate默认情况不会自动保存关联变量到数据库中,不论是CRUD的任何操作,都默认不自动存储(不会产生集联)。

那么如果需要设置自动操作关联对象的话,可以使用cascade例如当前在@ManyToOne中设置:

?
1
2
3
@ManyToOne (cascade={
             CascadeType.ALL
     })

这里cascade中需要一个数组的参数,参数均为CascadeType,其中CascadeType的类型有如下几种:

 

 
 
  1. CascadeType.ALL,//所有操作 
  2. CascadeType.MERGE,//合并 
  3. CascadeType.PERSIST,//保存 
  4. CascadeType.REFRESH,//刷新 
  5. CascadeType.REMOVE  //删除 

 

总结:默认情况下有关联的对象,不论任何形式的关系映射,不论单向还是双向,在Session进行持久化时都互不影响也不自动建立集联;如果需要自动建立集联关系到数据库中,那么在关系映射的注解上设置cascade!

另外一点:双向关系在程序中要设定双向的内存关联关系,并且双向需要设置mappedBy!

要注意!使用CascadeType.ALL之外的类型,必须使用对应的函数方法才行!

 

    对于Annotation中CRUD的R(read)操作:------------------------

1. 在CUD操作时cascade才会有集联影响,但是杜宇R读取时使用fetch!

2.默认情况下在读取ManyToOne 取出任何一个Many中的对象,那么对应的One会默认取出来;

默认情况下 在读取OneToMany时取出One的时,默认Many不会取出来;

如果需要手动设置可以使用fetch;

fetch有两个值:

1). EAGER  (立刻的)

2). LAZY  (懒惰d的)

如果你想在OneToMany时取出One的时候立刻取出所有其他many的,可以设置如下:

@OneToMany(fetch=FetchType.EAGER)  这样就会取出One的时候取出所有的Many对象

备注:当你OneToMany使用EAGER的时候,可以在sessionFactory关闭后仍然可以取Many中的任意一个元素,但是如果ManyToOne并使用LAZY的时候你在sessionFactory关闭后不可以取出One,因为是LAZY默认不会帮你取出One!

注意:1)两方不要同事设置Eager(会有多余的查询语句发出)

                     2) 对多方设fetch时要注意:一般用Lazy ;

对于Annotation中CRUD的U(update)操作:------------------------

简单;update不多说;

对于Annotation中CRUD的D(delete)操作:------------------------

默认delete的时候,例如:ManyToOne,那么删除many中的一个元素时,那么Hibernate会首先删除对应的元素,然后继续删除对应关联的One,那么发现表中(Many)还有其他的元素,会先删除所有其他的Many元素,最后删除One;

解决方案:

1)使用其他的cascade,不直接使用ALL类型;

2)打破关联关系。利用致null,将关联的One可以set为null,再删除对应记录即可;

3)使用HQL语句删除

.......................................集合映射.................................

一般使用如下集合:

Set(HashSet) 一般情况下使用;

List (ArrayList) 一般需要排序的时候使用;

排序可以使用注解:@OrderBy("name ASC")

Map (HashMap)    需要注视  @MapKey(name="id")

 

.......................................继承映射.................................

继承映射有三种形式:

1)使用一张表的形式  : SINGLE_TABLE

2) 没各类分别一张表 TABLE_PER_CLASS

3) 每个子类一张表  JOINED










本文转自 xiaominghimi 51CTO博客,原文链接:http://blog.51cto.com/xiaominghimi/969785,如需转载请自行联系原作者
目录
相关文章
|
1月前
|
Java 数据库连接 API
解锁高效开发秘籍:深入探究 Hibernate 如何优雅处理一对多与多对多关系,让数据映射再无烦恼!
【9月更文挑战第3天】Hibernate 是 Java 领域中最流行的 ORM 框架之一,广泛用于处理实体对象与数据库表之间的映射。尤其在处理复杂关系如一对多和多对多时,Hibernate 提供了丰富的 API 和配置选项。本文通过具体代码示例,展示如何使用 `@OneToMany`、`@JoinColumn`、`@ManyToMany` 和 `@JoinTable` 等注解优雅地实现这些关系,帮助开发者保持代码简洁的同时确保数据一致性。
32 4
|
1月前
|
SQL Java 数据库连接
Hibernate 批量操作来袭!掌握最佳实践,轻松应对数据洪流,开启高效开发新时代
【9月更文挑战第3天】在软件开发中,高效数据操作至关重要。作为流行的Java持久化框架,Hibernate提供了强大的数据库操作功能。本文探讨了Hibernate批量操作,包括批量插入、更新和删除的最佳实践,通过使用原生SQL和`Session`的`createNativeQuery()`方法,结合`addBatch()`及`executeBatch()`方法实现高效批量操作。合理设置批量大小、事务管理和性能测试是优化的关键。在实际开发中,应根据业务需求和性能要求选择合适的方法,以提升程序性能和可维护性。
94 3
|
2月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
38 1
|
2月前
|
Java 数据库连接 数据库
AI 时代风起云涌,Hibernate 实体映射引领数据库高效之路,最佳实践与陷阱全解析!
【8月更文挑战第31天】Hibernate 是一款强大的 Java 持久化框架,可将 Java 对象映射到关系数据库表中。本文通过代码示例详细介绍了 Hibernate 实体映射的最佳实践,包括合理使用关联映射(如 `@OneToMany` 和 `@ManyToOne`)以及正确处理继承关系(如单表继承)。此外,还探讨了常见陷阱,例如循环依赖可能导致的无限递归问题,并提供了使用 `@JsonIgnore` 等注解来避免此类问题的方法。通过遵循这些最佳实践,可以显著提升开发效率和数据库操作性能。
72 0
|
2月前
|
数据库 开发者 Java
颠覆传统开发:Hibernate与Spring Boot的集成,让你的开发效率飞跃式提升!
【8月更文挑战第31天】在 Java 开发中,Spring Boot 和 Hibernate 已成为许多开发者的首选技术栈。Spring Boot 简化了配置和部署过程,而 Hibernate 则是一个强大的 ORM 框架,用于管理数据库交互。将两者结合使用,可以极大提升开发效率并构建高性能的现代 Java 应用。本文将通过代码示例展示如何在 Spring Boot 项目中集成 Hibernate,并实现基本的数据库操作,包括添加依赖、配置数据源、创建实体类和仓库接口,以及在服务层和控制器中处理 HTTP 请求。这种组合不仅简化了配置,还提供了一套强大的工具来快速开发现代 Java 应用程序。
86 0
|
2月前
|
数据库 开发者 Java
Hibernate映射注解的魔力:实体类配置的革命,让你的代码量瞬间蒸发!
【8月更文挑战第31天】Hibernate 是一款出色的对象关系映射框架,简化了 Java 应用与数据库的交互。其映射注解让实体类配置变得直观简洁。本文深入剖析核心概念与使用技巧,通过示例展示如何简化配置。
28 0
|
2月前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
46 0
|
3月前
|
SQL Java 数据库连接
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
60 0
|
5月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
4月前
|
Java 数据库连接 数据库
探索JPA生态:Hibernate与其他ORM框架的对比分析
【6月更文挑战第25天】**JPA标准下的Hibernate是流行的ORM实现,提供丰富功能如二级缓存和延迟加载,但其学习曲线较陡,性能优化复杂。相比如MyBatis,Hibernate的JPQL更面向对象,MyBatis则接近SQL。选择ORM需考虑项目需求和个人偏好。**
70 0