Spring Data JPA 项目配置与QueryDSL集成

2023-11-09 06:36

本文主要是介绍Spring Data JPA 项目配置与QueryDSL集成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、说明

Spring Data JPA通过Spring Initializer创建时勾选相关依赖即可引入,QueryDSL需要单独引入。Spring JPA针对QueryDSL有比较好的兼容性,可以实现优雅的SQL构建。

二、设置JPA默认配置(yaml格式)

spring:jpa:hibernate:ddl-auto: updateshow-sql: true
# 自行填写数据源

以上配置会打印hibernate的sql,同时启用自动建表。

ddl-auto有以下四种模式:

create, create-drop, update, validate, none

一般,我们生产环境使用validate或者none,开发环境选择create、update

create每次启动清空数据且重建表,但是程序退出时不清空数据
create-drop每次启动清空数据且重建表,但是程序退出时会自动清空数据
update若无表,则建表,若有表,则alter

validate

仅与实体类校验,不符合就报错
none不配置,不进行ddl

三、安装JPA Buddy

需要到插件市场安装JPA Buddy,原版该插件为收费插件,目前已被Jetbrains收购,改为免费官方插件,Ultimate用户不需要额外付费。

四、JPA Buddy(JPA Designer)创建实体类和DAO

右键单选、多选目标数据表后,点击JPA Entities from DB可以快速创建实体类:

可在此处进行配置修改

其中,ID generation也就是主键生成策略需要注意下,None代表需要用户自己从代码去实现、SEQUENCE代表由数据库管理、IDENTITY代表ORM来管理,比如说UUID类的主键,建议通过ORM来管理。

创建完成后会打开:

此时会发现页面上方有一些多出来的按钮:

其实就是比如说添加实体属性、快速创建方法、创建DTO等功能。此处不再讲解。使用非常简单,有兴趣的读者可以自行试用。

本章主要讲解Spring JPA的启用和集成QueryDSL。

五、(附)已有JPA相关工程文件时访问JPA Designer

如果已经有Repository之类的JPA工程文件,进入到工程文件后右侧工具栏会展示JPA Designer的快捷方式,下面以新增JPA Entity实体类为例:

在快捷工具栏选择JPA Designer,点击+符号,选择JPA Entities from DB或其他选项,该选项是用来逆向工程数据库字段设计,创建JPA实体类。

注意,需要通过IDEA自带的数据库管理工具添加数据源,几乎市面上常见的数据源都支持:

添加成功后,点击刷新:

六、安装QueyDSL相关依赖和APT处理插件

<dependency><groupId>com.querydsl</groupId><artifactId>querydsl-jpa</artifactId><version>${querydsl.version}</version>
</dependency>
<dependency><groupId>com.querydsl</groupId><artifactId>querydsl-sql</artifactId><version>${querydsl.version}</version>
</dependency>

querydsl-sql不是必选项,用于解除querydsl-jpa不支持的一些复杂查询的限制。 

<project><build><plugins>...<plugin><groupId>com.mysema.maven</groupId><artifactId>apt-maven-plugin</artifactId><version>1.1.3</version><executions><execution><goals><goal>process</goal></goals><configuration><outputDirectory>target/generated-sources/java</outputDirectory><processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor></configuration></execution></executions><dependencies><dependency><groupId>com.querydsl</groupId><artifactId>querydsl-apt</artifactId><version>${querydsl.version}</version></dependency></dependencies></plugin><!--这里填写其他项目插件--></plugins></build>
</project>

 以上querydsl.version一般springboot-dependencies会自带,如果没有请自己去填写。

七、生成APT类

运行下compile把JPA类利用APT生成一下(后续如果表变动过,需要重clean再生成)

生成后的效果:

此时,由于生成后的代码在target目录下我们不能引用,需要IDEA修改下目录属性,把target/generated-sources设置为:

八、创建全局JPAQuery工厂

注意entityManager需要通过PersistenceContext注解管理,这是因为请求并非在一个线程中处理。

@Configuration
public class JPAQueryDSLConfiguration {@PersistenceContextprivate final EntityManager entityManager;public JPAQueryDSLConfiguration(EntityManager entityManager) {this.entityManager = entityManager;}@Beanpublic JPAQueryFactory jpaQueryFactory() {return new JPAQueryFactory(entityManager);}
}

九、测试 

    @AutowiredJPAQueryFactory QueryFactory;
    @GetMapping("/test")public RestResult<CenterEntity> testJPA() {CenterEntity ce1 = new CenterEntity();ce1.setCenterHost("10.10.10.7");ce1.setCenterVersion(CenterType.NEXT_A);ce1.setCenterPassword("password");cr.save(ce1);QCenterEntity qc = QCenterEntity.centerEntity;List<CenterEntity>  ce = QueryFactory.selectFrom(qc).where(qc.centerHost.eq("10.10.10.7").and(qc.centerPassword.startsWith("pass"))).fetch();return RestResult.success(ce.get(0));}

目前正常创建数据库插入条目、querydsl也已生效。已经实现了QueryDSL和JPA的简单集成。

Repository也可继承QuerydslPredicateExecutor,用Predicte参数动态构造谓词来查询条件。

这篇关于Spring Data JPA 项目配置与QueryDSL集成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/374486

相关文章

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2