图源:简书 (jianshu.com) 惰性加载带来的问题 在实体类之间建立关系时,可以选择“惰性加载”,比如: @Entity public class Student { // ... @OneToMany(mappedBy = "student", cascade = CascadeType.ALL, fetch = FetchType.LAZY) @Builder.Default private List<Email> emails …
图源:简书 (jianshu.com) 惰性加载带来的问题 在实体类之间建立关系时,可以选择“惰性加载”,比如: @Entity public class Student { // ... @OneToMany(mappedBy = "student", cascade = CascadeType.ALL, fetch = FetchType.LAZY) @Builder.Default private List<Email> emails …
图源:简书 (jianshu.com) JPA 的查询参数分为两种: 命名参数(Named Parameters) 位置参数(Positional Parameters) 类似于 Python 中的函数的位置参数和指名参数。 本文的示例使用下面的实体类: @Entity public class Student { private static final int MAX_SCORE = 100; private static final int MIN_SCORE = 0; public e…
图源:简书 (jianshu.com) JPA 中的查询(Query)有三种类型: Query,用 Java 持久性查询语言(JPQL,Java Persistence Query Language)编写。 NativeQuery,纯 SQL 编写。 Criterial API Query,用编程的方式编写。 为了介绍这些查询,这里定义一个实体类: @Getter @Builder @NoArgsConstructor @AllArgsConstructor @Entity public class Student…
图源:简书 (jianshu.com) Hibernate 中的实体,由标识符(Identitifier)确定了其实体实例的唯一性,这对应于表中的主键。 @Id 对于单一属性作为标识符的情况,可以用@Id注解标注: @Entity(name = "Person5") @Inheritance(strategy = InheritanceType.TABLE_PER_CLASS) public class Person { @Id private Long id; } 被@Id标注的属性类型必须是 Jav…
图源:简书 (jianshu.com) 关系型数据库设计中是不存在继承概念的,但实体类可以用继承来组织代码结构,所以需要用一种方式将实体类的继承结构映射到表结构。 本文将介绍几种在 JPA(Hibernate)中映射实体类继承层次的方式。 @MappedSuperclass 第一种方式是用@MappedSuperclass标记超类(Super Class),超类并不对应任何表结构,而是体现在子类对应的表中都拥有超类的字段(每个子类对应一张表)。 @ToString @Getter @Setter @AllArgsC…
图源:简书 (jianshu.com) JPA(Hibernate)中有一些注解可以用于筛选实体和关系,本文将介绍这些注解。 @Where 有时候,我们希望对表中的数据进行“软删除”,即删除的时候只修改其标记位而不从表中物理删除。 对于存在软删除的表,在执行相应查询的时候都要考虑删除标记,即添加上相应字段的条件语句后进行查询。这样就显得很麻烦,持久层框架一般都会支持对这种情况的“自动处理”,比如 MyBatisPlus。 JPA(Hibernate) 同样支持这种做法,通过使用@Where注解实现: @Entity…
图源:简书 (jianshu.com) 关系型数据库的增删改查操作会因为有关联关系而存在“级联操作”的需要,体现在 JPA 中,就是实体中会定义的级联类型(Cascade Type)。 JPA 中的级联类型由枚举jakarta.persistence.CascadeType表示,包括: ALL PERSIST MERGE REMOVE REFRESH DETACH 这些级联类型对应实体对象的状态转换操作,具体可以参考这篇文章。 ALL包含其他所有的操作。 下面详细说明这些级联类型的用途和影响。 示例 本文将使用以下…
图源:简书 (jianshu.com) 在之前的文章中我们讨论了 JPA 中的一对一关系,实际上存在一种特殊的一对一关系,即将一个实体映射到多张表,本文会讨论这种关系。 我之前提过,有时候会因为性能上的考量将一张表拆分成多张表,虽然拆分后也可以用一对一关系来表示和实现,但这样并不是特别合适,因为一对一关系中一边的关系是可以为null的,比如说一个学生对应一个电子邮件地址,也可能有的学生没有电子邮件地址,此时email表可能就没有一条对应的数据。但如果是从同一张表上拆分出的两张表,必然存在一对一的关系,即使另一张表中…
图源:简书 (jianshu.com) Hibernate 支持多种日志模块,本文介绍如何在 Spring Boot 中使用 Log4j2记录 Hibernate 日志。 实际上本文是我在写上篇文章时遇到的各种坑和最终解决的记录。 首先需要添加 Log4j2 的依赖,并排除 Spring Boot 默认使用的 logging common 日志模块: <dependency> <groupId>org.springframework.boot</groupId> &l…
图源:简书 (jianshu.com) 之前用两篇文章介绍了 JPA 中的一对一关系和一对多关系,实际上日常开发更多见的是多对多关系,本文将介绍如何在 JPA 中实现实体的多对多关系。 假设这里有两张表,学生表和课程表,我们需要将其对应起来。这两张表之间存在多对多的关系:一个学生可以选择多个课程,一个课程可以被多个学生选择。 可以用数据模型表示为: 我们用一个中间表(关联表)保存两个表之间的这种多对多的关联关系。 这里有一个细节,两个表与关联表之间的关系是一对多的。这很好理解,一个学生可以在关联表中出现多次。同样的…
魔芋红茶
加一点PHP,加一点Go,加一点Python......
COPYRIGHT © 2021 icexmoon.cn. ALL RIGHTS RESERVED.
本网站由提供CDN加速/云存储服务
Theme Kratos Made By Seaton Jiang