提到JPA操作数据库,有的人惊叹于它的简洁与强大,有些人则会觉得不够灵活,影响实战效率,那么究竟JPA为何让人又爱又恨呢?
一 战前磨刀
01.认识 JPA
JPA-Java Persistence API,即Java持久化API
总得来说,JPA 为对象关系映射提供了⼀种基于 POJO 的持久化模型
简化数据持久化代码的开发⼯作
为 Java 社区屏蔽不同持久化 API 的差异
而我们常说的Hibernate又是什么呢?它其实是JPA的一种实现。
02. 认识 Spring Data
以前,Spring只是在内部实现了支持JDBC、JPA等的方式。后来,Spring将所有对于数据操作的工具都整理在了Spring Data中,Spring Data 在保留底层存储属性的同时,提供相对一致的、基于Spring的编程模型。
主要模块:
- Spring Data JPA
- Spring Data JDBC
- Spring Data Redis
- Spring Data MongoDB
03. 认识 Spring Data JPA
Spring Data JPA,即Spring对JPA的封装。
官网上讲:Spring Data JPA旨在通过将工作量减少到实际需要的数量,来显著改善数据访问层的操作
作为开发人员,你只需要写你的repository接口,包括自定义的方法,Spring会自动提供实现
04. 常用的jpa实体类注解
通过JPA提供的一些实体类注解,我们可以配置一个对应的表,从而在程序运行时,JPA可以自动实现为我们建表的工作
常见的JPA实体类注解如下:
实体
• @Entity @MappedSuperclass
• @Table(name)
@Entity与@MappedSuperclass都是声明实体类的注解。
@Entity表示所声明的实体类里面定义的所有属性,均与对应的表关联
@MappedSuperclass表示所注解的类为一个父类,子类可以通过继承该父类来扩展自己的属性
@Table(name),表明该实体类与数据库中的某个表关联
主键
• @Id
• @GeneratedValue(strategy, generator)
• @SequenceGenerator(name, sequenceName)
@Id和@GeneratedValue常常组合起来,用于主键声明,并指定主键生成策略和生成器(若不指定,JPA会根据所引入驱动依赖的数据库进行默认策略的设置)
@SequenceGenerator注解,表示主键会采用系列号的方式生成映射
•@Col