SpringBoot-Spring Data Jpa使用(一)

简介:

名词解释

  • JPA:JPA是Java Persistence API的简称,由sun公司提出的ORM规范,具体实现由各个ORM框架(Hibernate,Toplink)去实现,统一了ORM框架的使用,开发人员更容易切换和学习ORM框架.
  • Spring Data:是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算数据服务。 Spring Data 包含多个子项目包括JPA Hadoop 等
  • Spring Data JPA:Spring Data其中的一个项目,整合JPA的使用,实现了基本的增删改查,分页的操作。
    下图展示了这个关系图,出处

基础知识

基本框架的搭建和使用,可以参考这个两个大神的博客纯洁的微笑程序员DD

这两篇博客中有点没有提到,我们的dao继承了JpaRepository之后已经可以对数据做简单的增删改查了。还有一个JpaSpecificationExecutor可以继承,继承之后可以使用jpa的模式进行查询.

查询

在spring data jpa中有4种查询方式,下面介绍每种方式和简介

自定义简单查询

  • 简介: 在dao中增加接口方法,并按照spring data jpa支持的模式命名方法,spring data jpa会按照指定规则生成sql语句,详细匹配规则可以参照纯洁的微笑博客中“自定义简单查询”部分
  • 示例:
public interface TestDao extends JpaRepository<Test, Long> {
 List<Test>findByKeyword(String keyword);
}

通过Example查询

  • 简介:JpaRepository接口中包含了QueryByExampleExecutor,这个接口支持将实体作为参考进行查询
  • 示例:
//service中使用继承了JpaRepository接口的dao
  public List<Test> findTests() {
  Test test = new Test();
  test.setName("aaa");
  return testDao.findAll(Example.of(test));
 }
  • 注意事项:实体中只要有值的内容都会被放进查询条件中,若实体中包含基础类型例如int 就会以0进行匹配。

@Query注解查询

  • 简介: 在dao中增加接口方法并在方法上增加@Query注解并在注解中写hql语句来进行查询
  • 示例:
public interface TestDao extends JpaRepository<Test, Long> {
 @Query("select t from Test t where t.name = :keyWord")
 List<Test>findTest(@Param("keyWord") String keyWord);
}

@Query参数说明:

名称 简介
value 指定JPQL语句,当nativeQuery=true时是原生的sql语句
countQuery 指定count的JPQL语句,不指定则自动生成,当nativeQuery=true时是原生的sql语句
countProjection 依据哪个字段来count一般默认即可
nativeQuery 默认是false,表示value 里面是不是原生的Sql 语句
name 指定一个query 的名字,必须是唯一的。 如果不指定,默认的生成规则是:{$domainClass}.${queryMethodName}
countName 指定一个count 的query 名字,必须是唯一的。如果不指定,默认的生成规则是:{$domainClass}.${queryMethodName}.count

查询结果格式

Entity-List

使用默认形式即可

Map-List

  • 注意:其中as name必须写,不写则map中key为下标。
 @Query("select new map(t.name as name,t.value as value) from Test t where t.name = :keyWord")
 List<Map<String,Object>>findTest(@Param("keyWord") String keyWord);

Vo-List

  • 注意:与Map类似,使用构造方法的形式进行初始化,传入顺序必须与构造函数顺序一致
 @Query("select new TestVo(t.name as name,t.value as value) from Test t where t.name = :keyWord")
 List<TestVo>findTest(@Param("keyWord") String keyWord);
public class TestVo{
    private String name;
    private String value;
    public TestVo(String name,String value){
        this.name = name;
        this.value = value;
    }
    // get..set..
}

Projection-List

  • 注意:TestProjection为接口,有对应的get方法,这种模式就不需要使用new的方式传值
 @Query("select t.name as name,t.value as value from Test t where t.name = :keyWord")
 List<TestProjection>findTest(@Param("keyWord") String keyWord);
public interface TestProjection{
    String getName();
    String getValue();
}

排序

  • 静态排序: 直接在jpql语句中直接写就可以了
  • 参数排序:
    • JpaSort.unsafe("排序规则"):会把排序语句直接追加到sql之后,当排序规则不单纯是属性而是需要进行一定处理时使用,例如:length(属性名)
    • Sort.by("属性名") :会进行安全检查,属性名必须是实体中属性
 @Query("select t.name as name,t.value as value from Test t where t.name = :keyWord")
 List<TestProjection>findTest(@Param("keyWord") String keyWord,Sort sort);
  //service中
 List<TestProjection>findTest(String keyWord,String prop){
    testdao.findTest(keyWord,Sort.by(prop))
 }

分页

在dao方法中增加Pageable pageable参数即可org.springframework.data.domain.Pageable,

 @Query("select t from Test t where t.name = :keyWord")
Page<Test> findTest(@Param("keyWord") String keyWord,Pageable pageable);

下一篇详细介绍最后一种 Specification查询,就是使用jpa api去查询

参考资料

https://www.cnblogs.com/zj0208/p/6008627.html
https://www.cnblogs.com/ityouknow/p/5891443.html
http://blog.didispace.com/springbootdata2/
https://blog.csdn.net/Phapha1996/article/details/78994395
https://www.baeldung.com/spring-data-jpa-query


 

来自为知笔记(Wiz)

目录
相关文章
|
2月前
|
NoSQL Java 数据库连接
《深入理解Spring》Spring Data——数据访问的统一抽象与极致简化
Spring Data通过Repository抽象和方法名派生查询,简化数据访问层开发,告别冗余CRUD代码。支持JPA、MongoDB、Redis等多种存储,统一编程模型,提升开发效率与架构灵活性,是Java开发者必备利器。(238字)
|
2月前
|
存储 Java 关系型数据库
Spring Boot中Spring Data JPA的常用注解
Spring Data JPA通过注解简化数据库操作,实现实体与表的映射。常用注解包括:`@Entity`、`@Table`定义表结构;`@Id`、`@GeneratedValue`配置主键策略;`@Column`、`@Transient`控制字段映射;`@OneToOne`、`@OneToMany`等处理关联关系;`@Enumerated`、`@NamedQuery`支持枚举与命名查询。合理使用可提升开发效率与代码可维护性。(238字)
323 1
存储 JSON Java
522 0
|
3月前
|
SQL Java 数据库连接
Spring Data JPA 技术深度解析与应用指南
本文档全面介绍 Spring Data JPA 的核心概念、技术原理和实际应用。作为 Spring 生态系统中数据访问层的关键组件,Spring Data JPA 极大简化了 Java 持久层开发。本文将深入探讨其架构设计、核心接口、查询派生机制、事务管理以及与 Spring 框架的集成方式,并通过实际示例展示如何高效地使用这一技术。本文档约1500字,适合有一定 Spring 和 JPA 基础的开发者阅读。
368 0
|
5月前
|
NoSQL Java Redis
Redis基本数据类型及Spring Data Redis应用
Redis 是开源高性能键值对数据库,支持 String、Hash、List、Set、Sorted Set 等数据结构,适用于缓存、消息队列、排行榜等场景。具备高性能、原子操作及丰富功能,是分布式系统核心组件。
585 2
|
6月前
|
Java API 数据库
JPA简介:Spring Boot环境下的实践指南
上述内容仅是JPA在Spring Boot环境下使用的冰山一角,实际的实践中你会发现更深更广的应用。总而言之,只要掌握了JPA的规则,你就可以借助Spring Boot无比丰富的功能,娴熟地驾驶这台高性能的跑车,在属于你的程序世界里驰骋。
230 15
|
7月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
248 32
|
8月前
|
NoSQL 安全 Java
深入理解 RedisConnectionFactory:Spring Data Redis 的核心组件
在 Spring Data Redis 中,`RedisConnectionFactory` 是核心组件,负责创建和管理与 Redis 的连接。它支持单机、集群及哨兵等多种模式,为上层组件(如 `RedisTemplate`)提供连接抽象。Spring 提供了 Lettuce 和 Jedis 两种主要实现,其中 Lettuce 因其线程安全和高性能特性被广泛推荐。通过手动配置或 Spring Boot 自动化配置,开发者可轻松集成 Redis,提升应用性能与扩展性。本文深入解析其作用、实现方式及常见问题解决方法,助你高效使用 Redis。
852 4
|
8月前
|
SQL Java 编译器
深入理解 Spring Data JPA 的导入与使用:以 UserRepository为例
本文深入解析了 Spring Data JPA 中 `UserRepository` 的导入与使用。通过示例代码,详细说明了为何需要导入 `User` 实体类、`JpaRepository` 接口及 `@Repository` 注解。这些导入语句分别用于定义操作实体、提供数据库交互方法和标识数据访问组件。文章还探讨了未导入时的编译问题,并展示了实际应用场景,如用户保存、查询与删除操作。合理使用导入语句,可让代码更简洁高效,充分发挥 Spring Data JPA 的优势。
480 0
|
Java 数据库连接 API
【Java笔记+踩坑】Spring Data JPA
从常用注解、实体类和各层编写方法入手,详细介绍JPA框架在增删改查等方面的基本用法,以及填充用户名日期、分页查询等高级用法。
【Java笔记+踩坑】Spring Data JPA

热门文章

最新文章