专栏首页Happy的分享【快学springboot】7.使用Spring Boot Jpa

【快学springboot】7.使用Spring Boot Jpa

jpa简介

Jpa (Java Persistence API) 是 Sun 官方提出的 Java 持久化规范。它为 Java 开发人员提供了一种对象/关联映射工具来管理 Java 应用中的关系数据。它的出现主要是为了简化现有的持久化开发工作和整合 ORM 技术。值得注意的是,JPA只是一套规范,不是具体的实现。Java很喜欢自己去定义规范,然后让厂商自己去实现,比如JMS等。

Spring Data JPA

Spring Data JPA是 Spring 基于 ORM(hibernate) 框架、Jpa 规范的基础上封装的一套 Jpa 应用框架,按照约定好的【方法命名规则】写数据库(DAO)层接口,就可以在不写接口实现的情况下,实现对数据库的访问和操作。同时提供了很多除了CRUD之外的功能,如分页、排序、复杂查询等等。

springboot整合JPA

  • maven依赖
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
 <groupId>mysql</groupId>
 <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
 <groupId>com.alibaba</groupId>
 <artifactId>druid-spring-boot-starter</artifactId>
 <version>1.1.10</version>
</dependency>
复制代码

这里我引入了阿里巴巴的druid数据库连接池。

在application.properties配置数据库连接

spring.datasource.druid.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai
spring.datasource.druid.username=root
spring.datasource.druid.password=123456
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
复制代码

这里基本是固定的写法了,不同的是,这里的数据库连接池我使用了阿里巴巴的连接池。

在application.properties配置spring data jpa一些信息

spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
复制代码

spring.jpa.database-platform主要是指定生成表名的存储引擎为 InnoDBD

show-sql 是否打印出自动生成的 SQL,方便调试的时候查看

spring.jpa.hibernate.ddl-auto参数的作用主要用于:自动创建更新验证数据库表结构,有五个值

  1. create: 每次加载 hibernate 时都会删除上一次的生成的表,然后根据你的 model 类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
  2. create-drop :每次加载 hibernate 时根据 model 类生成表,但是 sessionFactory 一关闭,表就自动删除。
  3. update:最常用的属性,第一次加载 hibernate 时根据 model 类会自动建立起表的结构(前提是先建立好数据库),以后加载 hibernate 时根据 model 类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。
  4. validate :每次加载 hibernate 时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。
  5. none:什么都不做

添加一个实体类UserEntity

@Entity
@Table(name = "user")
@Data
public class User {
 @Id
 @GeneratedValue(strategy = GenerationType.SEQUENCE)
 private Integer id;
 @Column(name = "username", unique = true, nullable = true, length = 50)
 private String username;
 private String password;
}
复制代码

可以使用Column注解来定义一些数据库表结构的东西,如果不使用,会自动使用驼峰的命名规则映射默认值。

启动springboot项目,自动生成数据库表

这里生成了User表,可以看下它的表结构:

这里还生成了一个hibernate_sequence表:

主要是因为我设置了主键的值策略为GenerationType.SEQUENCE,它是根据这个表来实现自增的。

添加一个UserRepo接口

public interface UserRepo extends PagingAndSortingRepository<User, Integer>, JpaSpecificationExecutor<User> {
 
}
复制代码

这里继承了PagingAndSortingRepository和JpaSpecificationExecutor两个接口,前者帮我们实现了CRUD、排序和分页等简单查询,后者是用来构造一些比较复杂的查询用的。

UserRepo默认给我们提供的方法

userRepo.findById(1);
userRepo.findAll();
userRepo.findAll(PageRequest.of(0, 10));
userRepo.deleteById(1);
User user = new User();
userRepo.save(user);
复制代码

这里是基础的CRUD的使用方法了。需要注意的是,修改实体的话,是根据save方法来判断的,如果save的实体是从数据库里查出来的,save的时候就是修改。

自定义查询方法

User findUserByUsername(String username);
User findUserByUsernameAndPassword(String username,String password);
复制代码

spring data jpa有一套映射到sql查询的方法命名规则。整理如下:

使用这些提供的查询方法,基本上可以应付我们需要的单表查询了。

分页查询

Page<User> findALL(Pageable pageable);
Page<User> findByUserName(String userName,Pageable pageable);
复制代码

可以使用PageRequest.of(0, 10)来构建一个pageable。需要注意的是,这里分页从0开始。

自定义SQL查询

在UserRepo上,自定义方法。在 SQL 的方法上面使用@Query注解来写SQL,如涉及到删除和修改在需要加上@Modifying.也可以根据需要添加 @Transactional对事物的支持

@Transactional
@Modifying
@Query("update User u set u.username= ?1 where u.id = ?2")
int modifyByIdAndUserId(String username, Integer id);
 
@Transactional
@Modifying
@Query("delete from User where id = ?1")
void deleteByUserId(Long id);
复制代码

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【快学SpringBoot】快速上手好用方便的Spring Cache缓存框架

    缓存,在开发中是非常常用的。在高并发系统中,如果没有缓存,纯靠数据库来扛,那么数据库压力会非常大,搞不好还会出现宕机的情况。本篇文章,将会带大家学习Spring...

    Happyjava
  • 登录那些事(一):用简单的话来讲讲SSO单点登录

    每一个系统都做一套登录功能,登录了A系统之后,如果想要使用B系统,那么需要再登录一次,即使两个系统的账号是一致的。

    Happyjava
  • Java中的transient关键字

    之前写过一篇序列化相关的文章,今天要讲的这个文件自transient也是跟序列化有关系的。但是,挺多人没有了解过该关键字甚至是不知道该关键字的存在。

    Happyjava
  • 【重构】Spring Cloud OAuth 无Token调用源码封装

    书接上回Spring Security OAuth 微服务内部Token传递的源码解析,本篇主要无token 调用过程中,代码的不断完善及其重构过程。

    冷冷
  • 【IT资讯】三问三星Note7爆炸真相:这事,不能翻篇

    昨天上午,三星正式召开新闻发布会,对外公布了三星Note7爆炸事件的调查结果。对于三星来讲,新闻发布会意味着Note7“炸机门”的真相已经水落石出,事情已经画上...

    李海彬
  • 三星宣布年底关闭天津工厂

    据了解,三星天津工厂现有员工约2600名,每年的智能手机产能在3600万部左右。而有关员工的后续安排,三星方面表示,和此前关闭的深圳工厂不同,因为天津工厂人数较...

    镁客网
  • [NewLife.XCode]反向工程(自动建表建库大杀器)

    NewLife.XCode是一个有10多年历史的开源数据中间件,支持nfx/netstandard,由新生命团队(2002~2019)开发完成并维护至今,以下简...

    大石头
  • GDB调试指南-单步调试

    前面通过《启动调试》,《断点设置》,《变量查看》,我们已经了解了GDB基本的启动,设置断点,查看变量等,如果这些内容你还不知道,建议先回顾一下前面的内容。在启动...

    编程珠玑
  • 三星奋斗记:从卖面条的小店到世界芯片业第一

    镁客网
  • 三星关闭天津工厂后续,将新建新能源电池工厂

    本周,三星宣布将于年底关闭位于天津的工厂后,各种关于三星的传闻铺天盖地而来,比如三星要从中国撤资,但根据新华社最新消息显示,三星只是将在天津的投资重点从智能手机...

    镁客网

扫码关注云+社区

领取腾讯云代金券