当前位置: 首页 > news >正文

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集成

一、说明 Spring Data JPA通过Spring Initializer创建时勾选相关依赖即可引入&#xff0c;QueryDSL需要单独引入。Spring JPA针对QueryDSL有比较好的兼容性&#xff0c;可以实现优雅的SQL构建。 二、设置JPA默认配置&#xff08;yaml格式&#xff09; spring:jpa:hibernate:…...

UE5数字孪生制作-数据篇(二) - 数据处理

1.卫星图与DEM高度图坐标一致处理 https://www.bilibili.com/video/BV1op4y1V71r?p4&vd_source707ec8983cc32e6e065d5496a7f79ee6 坐标系的调整 如何使用临时图层&#xff0c;对其他数据层进行裁切 &#xff08;1&#xff09;创建临时图层 &#xff08;2&#xff09;在临…...

Java 设计模式——享元模式

目录 1.概述2.结构3.实现3.1.抽象享元3.2.具体享元3.3.享元工厂3.4.测试 4.优缺点5.使用场景6.JDK 源码解析——Integer 类 1.概述 &#xff08;1&#xff09;享元模式 (Flyweight Pattern) 是一种结构型设计模式&#xff0c;主要通过共享对象来减少系统中的对象数量&#xff…...

再扩国产化适配版图,长安链新增数据库兼容性认证

基础软件的自主可控影响着国家信息安全与产业技术发展是否受制于人。实现真正长期可持续的技术自主可控&#xff0c;需要再进一步的是让国产化信息系统生态更有”活性“&#xff0c;基础软件之间、基础软件与其他国产上层应用的互相兼容、互相促进&#xff0c;共同繁荣发展&…...

MES系统数据集成系统源码

MES系统数据集成系统源码 1 MES的生产计划管理综述 生产计划的管理在MES系统中是非常重要的。我们知道&#xff0c;一般的情况下&#xff0c;企业的生产计划是由上层管理系统ERP来完成&#xff0c;那么MES中的生产计划和ERP的生产计划的不同点在于&#xff1a; ERP的生产计划…...

关于道一云-七巧使用感悟

低代码&#xff0c;开发快速&#xff0c;缺点组件比较少但能满足大多数场景&#xff0c;如果需要的话得自己造&#xff0c;官方的技术群里面普遍问题响应就很快&#xff0c;技术文档这个会抽风&#xff0c;有些代码就改个筛选条件本地死活运行不了&#xff0c;去官网那里问他们…...

去中心化数据云项目Oort主网即将上线

备受期待的去中心化数据云项目Oort&#xff0c;今日已通过官方X账号官宣&#xff0c;将于纽约时间11月27日正式上线主网Olympus Protocol。届时&#xff0c;用户也能够通过Oort的Ale Wallet钱包和开发者API使用主网&#xff0c;并可通过OORT浏览器查询交易和合约&#xff0c;开…...

CSS知识点梳理(一)

CSS 是层叠样式表&#xff08;Cascading Style Sheets&#xff09;的缩写&#xff0c;它是一种用于描述 HTML 或 XML&#xff08;包括如 SVG、MathML 等派生语言&#xff09;文档呈现的语言。CSS 可以用来控制文档的布局、颜色、字体等外观属性。 CSS 的主要特点包括&#xff…...

网络安全深入学习第八课——反向代理(工具:frp)

文章目录 一、实验环境二、实验要求三、开始模拟1、攻击机配置frp文件2、攻击拿下跳板机&#xff0c;并且上传frpc.ini、frpc.exe、frpc_full.ini文件3、把frps.ini、、frps.exe、frps_full.ini文件放到VPS主机上4、VPS机开启frp5、跳板机开启frp6、验证 一、实验环境 攻击机&…...

浅谈前端自定义VectorGrid矢量瓦片样式

目录 前言 一、VectorGrid相关API介绍 1、VectorGrid 2、 LayerStyles样式详解 二、样式自动配置 1、页面定义 2、地图及PBF瓦片引入 3、矢量瓦片样式定义 4、鼠标事件交互 三、最终效果 1、自定义样式展示 2、鼠标交互 总结 前言 在上一篇博客中&#xff0c;详细讲…...

Qt5多线程<12>

1.多线程的简单实现 <1> 在头文件threaddlg.h声明用于界面显示所需的控件,其代码如下: #ifndef THREADDLG_H #define THREADDLG_H#include <QDialog> #include <QPushButton> #include "workthread.h" #define MAXSIZE 5class ThreadDlg : publ…...

Linux学习笔记之五(父子进程、孤儿进程、僵尸进程、守护进程)

Linux 1、进程1.1、进程的六种状态1.2、创建子进程1.3、添加子进程任务1.4、孤儿进程、僵尸进程、守护进程1.4.1、避免僵尸进程1.4.2、创建守护进程1.4.3、杀死守护进程 1.5、综合练习 1、进程 进程可以简单的理解为一个正在执行的程序&#xff0c;它是计算机系统中拥有资源和…...

[题] 不容易系列之(3)―― LELE的RPG难题 #DP

题目 不容易系列之(3)―― LELE的RPG难题 思路 简单的DP题。 代码 #include<bits/stdc.h> using namespace std; //默认以0开头&#xff0c;以1和2结尾。f[i][1]表示长度为i的以1结尾的涂抹方案 //状态转移方程&#xff1a;若以1结尾&#xff0c;则前面一个格子只能是…...

pip 安装任意软件包报错

现象 使用 pip 命令时提示 查看源码 可以看到是从 pip 包中导入 main失败&#xff0c;点击查看目录 main 文件不见了&#xff0c;判断是文件缺失&#xff0c;重装 pip 即可 # python3 下载 pip curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py # python2 下载…...

NLP之Bert实现文本多分类

文章目录 代码代码整体流程解读debug上面的代码 代码 from pypro.chapters03.demo03_数据获取与处理 import train_list, label_list, val_train_list, val_label_list import tensorflow as tf from transformers import TFBertForSequenceClassificationbert_model "b…...

对话大众软件子公司:中国的智舱、智驾比欧洲早一代

作者 | 德新 编辑 | 王博 尤其在上海车展之后&#xff0c;大部分的外资车企都在转型调整。 2023年的上海车展是一个重要节点。在这之前&#xff0c;疫情阻断了国内和海外频繁的线下交流&#xff0c;而国内汽车的新能源化和智能化在这期间完成了一次飞跃式的发展。所以车展开…...

基于FPGA的图像RGB转HSV实现,包含testbench和MATLAB辅助验证程序

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1. RGB与HSV色彩空间 4.2. RGB到HSV转换原理 5.算法完整程序工程 1.算法运行效果图预览 将FPGA的仿真结果导入到matlab中&#xff1a; 2.算法运行软件版本 vivado2019.2 matlab2022a …...

小型企业如何数字化转型?ZohoCRM助力小企业转型

小型企业数字化之路倍加艰难&#xff0c;其组织规模有限、资源有限&#xff0c;数字化布局或转型&#xff0c;也存在与数字平台匹配度的问题。其实小型企业可以通过CRM客户管理系统实现高效的客户关系管理&#xff0c;进一步提高市场竞争力。 建立高效易用的客户关系管理系统 …...

聊聊模板引擎<Template engine>

模板引擎是什么 模板引擎是一种用于生成动态内容的工具&#xff0c;通常用于Web开发中。它能够将静态的模板文件和动态数据结合起来&#xff0c;生成最终的HTML、XML或其他文档类型。模板引擎通过向模板文件中插入变量、条件语句、循环结构等控制语句&#xff0c;从而实现根据…...

多平台商品采集——API接口:支持淘宝、天猫、1688、拼多多等多个电商平台的爆款、销量、整店商品采集和淘客功能

item_get-获得淘宝商品详情 item_get_app-获得淘宝app商品详情原数据 item_get_pro-获得淘宝商品详情高级版 item_search-按关键字搜索淘宝商品 item_search_img-按图搜索淘宝商品&#xff08;拍立淘&#xff09; item_search_shop-获得店铺的所有商品 API请求地址 公共…...

别再手动跑代码了!用这个在线工具5分钟搞定DESeq2差异分析(附完整流程)

零代码时代&#xff1a;5分钟完成DESeq2差异分析的在线工具全攻略 生物信息学分析的门槛正在被新技术不断降低。还记得十年前&#xff0c;要完成一次RNA-seq差异表达分析&#xff0c;研究者必须掌握R语言基础、理解Bioconductor生态系统、能调试各种报错信息——这往往需要数周…...

揭秘C++ MCP网关核心设计:从epoll+无锁队列到内存池预分配,3大吞吐翻倍关键技术全公开

第一章&#xff1a;C MCP网关架构全景与性能目标定义C MCP&#xff08;Microservice Control Plane&#xff09;网关是面向高吞吐、低延迟微服务通信场景设计的核心基础设施组件&#xff0c;其核心职责涵盖协议转换、路由决策、熔断限流、可观测性注入及安全策略执行。该网关并…...

VNC如何同步粘贴复制

1、右击控制的桌面图标2、点击 Properties&#xff0c;找到 Expert3、在 Filter 里搜索 clipboard下面三个改成图示就可以了4、jetson端开启 clipboard bridge在 Jetson 终端运行&#xff1a;sudo apt update sudo apt install autocutsel然后运行&#xff1a;autocutsel -fork…...

Chrome 91+ 开发环境登录失效?别慌,教你用命令行参数搞定SameSite默认策略

Chrome 91开发环境登录失效&#xff1f;SameSite策略变更的深度解决方案 周一早上9点15分&#xff0c;李工像往常一样打开本地开发环境准备调试新功能&#xff0c;却发现无论如何都无法保持登录状态——每次跳转后Session就像被清空一样回到登录页。抓包工具显示后端确实返回了…...

AI应用的可观测性工程:用Tracing和Logging看清LLM黑盒

“我的RAG系统回答了一个错误答案&#xff0c;但我不知道为什么。” “Agent跑了2分钟什么都没完成&#xff0c;我不知道它在做什么。” “用了新版本Prompt&#xff0c;感觉质量变了&#xff0c;但我说不清楚哪里变了。” 这些是AI工程师最常见的困境&#xff0c;根本原因是缺…...

real-anime-z镜像免配置优势:预编译CUDA内核+PyTorch 2.3兼容性保障

real-anime-z镜像免配置优势&#xff1a;预编译CUDA内核PyTorch 2.3兼容性保障 1. 镜像概述 real-anime-z是基于Z-Image构建的LoRA模型镜像&#xff0c;专注于生成高质量的真实风格动画图片。这个镜像的最大特点是开箱即用&#xff0c;无需繁琐的配置过程&#xff0c;特别适合…...

基础算法——区间合并

题目给定n个区间[li,ri]&#xff0c;要求合并所有有交集的区间。注意如果在端点处相交&#xff0c;也算有交集。输出合并完成后的区间个数。例如&#xff1a;[1,3]和[2,6]可以合并为一个区间[1,6]。输入格式第一行包含整数n。接下来n行&#xff0c;每行包含两个整数l和r。输出格…...

Godot游戏资源提取:3分钟学会PCK文件解包技巧

Godot游戏资源提取&#xff1a;3分钟学会PCK文件解包技巧 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker 你是否玩过Godot引擎开发的游戏&#xff0c;被里面的精美素材吸引却无法获取&#xff1f;Go…...

告别while死等!用STC15单片机定时器搞定按键短按长按(附完整代码)

STC15单片机定时器中断实现按键短按长按检测实战指南 在嵌入式开发中&#xff0c;按键处理是最基础却最容易出问题的环节之一。很多初学者都会遇到这样的困扰&#xff1a;按下按键后程序"卡死"了&#xff0c;数码管显示停滞、通信中断&#xff0c;直到松开按键才恢复…...

用STM32G431的SPI+DMA驱动WS2812B灯带:我的4bit编码方案与150MHz主频调优心得

STM32G431的SPIDMA驱动WS2812B灯带&#xff1a;4bit编码与150MHz主频调优实战 最近在做一个LED艺术装置项目时&#xff0c;遇到了一个有趣的挑战&#xff1a;如何用STM32G431驱动一批非标准WS2812B灯带。这些灯珠来自不知名厂商&#xff0c;时序要求与常规型号略有不同。经过两…...