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

【Spring Boot】Spring Boot中的简单查询

前面介绍了在Spring Boot项目中集成JPA框架,实现数据的增、删、改、查等功能。Spring Data JPA的使用非常简单,只需继承JpaRepository即可实现完整的数据操作方法,无须任何数据访问层和SQL语句。JPA除了这些功能和优势之外,还有非常强大的数据查询功能。以前复杂的查询都需要拼接很多查询条件,JPA有非常方便和优雅的方式来解决。接下来就聊一聊JPA的查询功能,从而体验Spring Data JPA的强大。

1.预生成方法

前面介绍了JpaRepository接口实现访问数据库的所有关键接口,比如exists()、save()、findAll()、delete()等方法。创建UserRepository类继承JpaRepository类,拥有父类中所有预先生成的方法。

调用这些方法也特别简单,上面所有JpaRepository父类拥有的方法都可以直接调用,无须声明。示例代码如下:

userRespository.existsByld((long) 1);
userRespository.save(user);
userRespository.findById((long) 1);
userRespository.findAll();
userRespository.delete(user);
userRespository.deleteById((long) 1);

2.自定义简单查询

JPA除了可以直接使用JpaRepository接口提供的基础功能外,还支持根据实体的某个属性实现数据库操作,Spring Data JPA能够根据其方法名为其自动生成SQL,支持的关键字有find、query、get、read、count、delete等,主要的语法是findByXX、queryByXX、getByXX、readByXX、countByXX等。利用这个功能,仅需要在定义的Repository中添加对应的方法名即可,无须具体实现,使用时Spring Data JPA会自动根据方法名来生成SQL语句。

2.1 属性查询

如果想根据实体的name属性来查询User的信息,那么直接在UserRepository中增加一个接口声明即可:

User findByUserName(String userName);

从上面的示例可以看到,我们可以在UserRepository接口中声明findByUserName方法,无须实现,JPA会自动生成对应的实现方法及其SQL语句。

2.2 组合查询

JPA不仅支持单个属性查询,还支持多个属性查询,根据And、Or等关键字进行组合查询,示例代码如下:

User findByNameOrPassword (String name, String password);

在上面的示例中,根据姓名和密码两个属性组合查询,属性名称与个数要与参数的位置与个数一一对应。可以根据查询的条件不断地添加和拼接,Spring Data JPA都可以正确解析和执行。

2.3 JPA关键字

JPA的自定义查询除了And、Or关键字外,基本上SQL语法中的关键字JPA都支持,比如like、between等。

按照Spring Data的规范,查询方法以find、read、get开头。涉及查询条件时,条件的属性用条件关键字进行连接。需要注意的是,条件属性首字母大写。

3.自定义SQL查询

一般的数据查询功能都可以通过定义方法名的方式来实现。但是有些特殊的场景,可能需要自定义的SQL来实现数据查询功能。Spring Data JPA同样可以完美支持,Spring Data JPA提供了@Query注解,通过注解可以自定义HQL或SQL实现复杂的数据查询功能。下面通过示例程序演示@Query注解实现自定义SQL查询。

3.1 HQL查询

在对应查询方法上使用@Query注解,在注解内写HQL来查询内容:

@Query("select u from User u")
List<User> findALL();

在上面的示例中,使用@Query注解定义自定义的HQL语句,实现自定义HQL语句查询。使用HQL比原生的SQL可读性更强,实现面向对象的方式操作数据。使用HQL时需要注意:

1)from后面跟的是实体类,而不是数据表名。

2)查询字段使用的是实体类中的属性,而不是数据表中的字段。

3)select后面不能跟“*”,应为实体类中的属性。

3.2 SQL查询

JPA除了支持HQL语句查询外,还可以直接使用SQL语句,这样比较直观,只需再添加一个参数“nativeQuery = true”即可:

@Query(value="select * from user u where u.name = ?1",nativeQuery = true)
List<User> findByName(String name);

上面示例中的“?1”表示方法参数中的顺序,“nativeQuery = true”表示执行原生SQL语句。除了按照这种方式传参外,还可以使用@Param传值方式:

@Query(value="select u from User u where u.password = :password")
List<User> findByPassword(@Param("password") String password);

3.3 修改和删除

除了自定义查询语句外,@Query注解同样可以用于定义修改和删除语句,只不过还需要加上@Modifying注解。示例代码如下:

@Modifying
@Query("update User set userName = ?1 where id = ?2")
int modifyById(String userName, Long id);@Modifying
@Query("delete from User where id = ?1")
void deleteUserById(Long id);

在上面的示例中,自定义delete和update语句需要添加@Modifying注解。需要注意的是,使用时需要在Repository或者更上层增加@Transactional注解,确保数据能成功写入数据库。

4.已命名查询

除了使用@Query注解外,还可以使用@NamedQuery与@NameQueries等注解定义命名查询。JPA的命名查询实际上就是给SQL查询语句起一个名字,执行查询时就是直接使用起的名字,避免重复写JPQL语句,使得查询方法能够复用。下面通过示例程序演示JPA已命名查询。

4.1 定义命名查询

在实体类中,@NamedQuery注解定义一个命名查询语句,示例代码如下:

@Entity
@Table(name="user")
@NamedQuery(name="findAllUser", query="SELECT U FROM User u")
public class User {}

在上面的示例中,@NamedQuery中的name属性指定命名查询的名称,query属性指定命名查询的语句。如果要定义多个命名查询方法,则需要使用@NamedQueries注解:

@Entity
@Table(name="users")
@NamedQueries({@NamedQuery(name = "findAllUser", query = "SELECT U FROM User u"),@NamedQuery(name = "findUserWithId", query = "SELECT U FROM User u WHERE u.id = ?1"),@NamedQuery(name = "findUserWithName", query = "SELECT U FROM User u WHERE u.name = :name")
})
public class User {}

在上面的示例中,在User实体类中定义了findAllUser()、findUserWithId()、findUserWithName()三种方法。

4.2 调用命名查询

定义命名查询后,可以使用EntityManager类中的createNamedQuery()方法传入命名查询的名称来创建查询:

    @ResourceEntityManagerFactory emf;@Testpublic void testNamedQuery() {EntityManager em = emf.createEntityManager();// 根User实体中定义的命名查询Query query = em.createNamedQuery("findUserWithName");query.setParameter("name", "ysxq");List<User> users = query.getResultList();for (User u : users) {System.out.println("name:" + u.getName() + ",age:" + u.getAge());}}

在上面的示例中,使用createNamedQuery创建对应的查询,JPA会先根据传入的查询名查找对应的NamedQuery,然后通过调用getResultList()方法执行查询并返回结果。

除了使用@NamedQuery注解的方式之外,Spring Data JPA提供的Named查询可以支持将SQL语句写至XML文件中,实现SQL与Java代码的分离。在resources/META-INF目录下创建orm.xml文件并定义命名方法,参考配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<entity-mappings version="2.0"xmlns="http://java.sun.com/xml/ns/persistence/orm"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/ormhttp://www.oracle.com/webfolder/technetwork/jsc/xml/ns/persistence/orm_2_2.xsd"><named-native-query name="findUserWithName2" result-class="com.example.ysxq.model.User"><description>通过name查询用户数据</description><query>select u.id , u.name , u.password , u.age from users u where u.name = :name</query></named-native-query>
</entity-mappings>

在orm.xml文件中使用标签定义queryByName的命名查询,使用XML的方式与使用@NamedQuery注解方式的效果是一样的。只是将SQL语句写至XML文件中,实现SQL与Java代码的分离,使得定义的Java实体类看起来不那么复杂、臃肿。

相关文章:

【Spring Boot】Spring Boot中的简单查询

前面介绍了在Spring Boot项目中集成JPA框架&#xff0c;实现数据的增、删、改、查等功能。Spring Data JPA的使用非常简单&#xff0c;只需继承JpaRepository即可实现完整的数据操作方法&#xff0c;无须任何数据访问层和SQL语句。JPA除了这些功能和优势之外&#xff0c;还有非…...

Transformer 01(自注意机制Self-attention)

一、Self-attention [台大李宏毅] 1.1 向量序列的输入 一个序列作为输入&#xff1a; 多个向量输入举例&#xff1a; 一个句子&#xff1a; 声音信号&#xff1a; 图&#xff1a; 1.2 输出 二、Sequence labeling 输入与输出一样多&#xff1a;Sequence labeling 窗口开的…...

交流共享,共筑智算底座丨九州未来受邀出席英特尔线下沙龙

随着AI技术的升级迭代、生成式AI模型智能化水平的持续提升&#xff0c;AIGC加速向多种场景渗透&#xff0c;AIGC迎来应用爆发期&#xff0c;有望实现且跨越更多领域的融合&#xff0c;形成新的应用场景和解决方案&#xff0c;持续推动数字技术的创新与应用&#xff0c;助力各行…...

【EI会议信息】第五届土木建筑与城市工程国际学术会议(ICCAUE 2023)

第五届土木建筑与城市工程国际学术会议&#xff08;ICCAUE 2023&#xff09; 2023 5th International Conference on Civil Architecture and Urban Engineering (ICCAUE 2023) 第五届土木建筑与城市工程国际学术会议&#xff08;ICCAUE 2023&#xff09;由天津大学主办&…...

上海亚商投顾:沪指震荡反弹 汽车产业链全天强势

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 大小指数昨日集体反弹&#xff0c;沪指3100点失而复得&#xff0c;创业板指一度涨超1.5%&#xff0c;随后涨幅…...

【Python深度学习】深度学习入门介绍

引言 深度学习是人工智能领域中最受关注和研究的子领域之一&#xff0c;它在计算机视觉、自然语言处理、语音识别、推荐系统等各个领域都有广泛的应用。本文将详细介绍深度学习的发展历史、不同类型、应用领域以及未来发展前景。 1、深度学习的发展历史 深度学习的起源可以追溯…...

【Linux系统编程】进程概念与基本创建

文章目录 1. 进程的概念2. 进程描述—PCB3. task_struct—PCB的一种4. task_ struct内容分类5. 查看进程 这篇文章我们来学习下一个概念——进程 1. 进程的概念 那什么是进程呢&#xff0c;我们该如何理解它呢&#xff1f; 如果我们打开电脑的任务管理&#xff1a; 我们看到这…...

webpack:详解CopyWebpackPlugin,复制的同时修改文件内容

摘要 CopyWebpackPlugin 是一个强大的 Webpack 插件&#xff0c;用于将文件从源目录复制到构建目录。在本文中&#xff0c;我们将探讨 CopyWebpackPlugin 的一些常用 API&#xff0c;并提供示例代码。 在构建 Web 应用程序时&#xff0c;通常需要将一些静态文件&#xff08;如…...

Twin-Builder—系统级多物理域数字孪生平台

Twin Builder是ANSYS公司系统仿真业务的核心产品&#xff0c;是一款跨学科多领域系统仿真软件和数字孪生平台。能够实现复杂系统的建模、仿真和验证&#xff0c;基于IIoT物联网平台对数字孪生体进行集成、部署与运行&#xff0c;在完成复杂系统功能、性能的验证和优化的同时&am…...

用selenium和xpath定位元素并获取属性值以及str字符型转json型

页面html如图所示&#xff1a; 要使用xpath定位这个div元素&#xff0c;并且获取其属性data-config的内容值。 from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.options import Optionshost127.0.0.1 port10808 …...

基于Java的电影院管理系统设计与实现

前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb;…...

Linux Static Key原理与应用

文章目录 背景1. static-key的使用方法1.1. static-key定义1.2 初始化1.3 条件判断1.4 修改判断条件 2、示例代码参考链接 背景 内核中有很多判断条件在正常情况下的结果都是固定的&#xff0c;除非极其罕见的场景才会改变&#xff0c;通常单个的这种判断的代价很低可以忽略&a…...

linux ssh 禁止指定用户通过ssh登录

Linux 禁止用户或 IP通过 SSH 登录 限制用户 SSH 登录 1.只允许指定用户进行登录&#xff08;白名单&#xff09;&#xff1a; 在 /etc/ssh/sshd_config 配置文件中设置 AllowUsers 选项&#xff0c;&#xff08;配置完成需要重启 SSHD 服务&#xff09;格式如下&#xff1a…...

快速学习Netty

Netty框架探索&#xff1a;助力高效网络编程 一、Netty是个啥&#xff1f;二、“Hello World”服务器端实现&#xff08;Server&#xff09;客户端实现&#xff08;Client&#xff09;思考&#x1f914; 三、Netty的核心组件EventLoopChannelChannelPipelineChannelHandlerByte…...

对类和对象的详细解析

目录 1.类的构成 2.this指针 3.C类里面的静态成员 3.1 类里面的静态成员函数 3.2 类里面的静态成员变量 静态成员变量的特点 共享性 存储位置 生命周期 访问权限 如何初始化&#xff1f; 构造函数 1.类的构成 public修饰的成员在类外可以直接被访问 private和protecte…...

matlab 间接平差法拟合二维圆

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。爬虫自重。 一、算法原理 圆的方程为: ( x - x 0 )...

pgzrun 拼图游戏制作过程详解(10)

10. 拼图游戏继续升级——多关卡拼图 初始化列表Photos用来储存拼图文件名&#xff0c;Photo_ID用来统计当下是第几张拼图&#xff0c;Squares储存当下拼图的24张小拼图的文件名&#xff0c;Gird储存当下窗口上显示的24个小拼图及坐标。 Photos["girl_","boy_…...

glog与pugi::xml使用方法

&#xff08;一&#xff09;glog的使用:google logging的简称&#xff1b; &#xff11;&#xff09;需要安装&#xff0c;网上一搜一大堆&#xff0c;不在赘述&#xff1b; &#xff12;&#xff09;在cmakelists.txt中&#xff0c;需要链接"-glog"&#xff0c;如&a…...

windows下MySQL服务不见,服务无法启动,服务闪退,提示“本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止”

文章目录 前情提示1.解决MySQL服务消失2.解决MySQL服务无法启动 前情提示 后台启动MySQL服务出现闪退 或 “本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止”&#xff0c;可以参考以下方法。 我的电脑上安装了双版本MySQL&#xff0c;这里…...

剑指offer(C++)-JZ67:把字符串转换成整数atoi(算法-模拟)

作者&#xff1a;翟天保Steven 版权声明&#xff1a;著作权归作者所有&#xff0c;商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处 题目描述&#xff1a; 写一个函数 StrToInt&#xff0c;实现把字符串转换成整数这个功能。不能使用 atoi 或者其他类似的库函数。…...

嵌入式笔试面试刷题(day15)

文章目录 前言一、Linux中的主设备号和次设备号1.查看方法2.主设备号和次设备号的作用 二、软件IIC和硬件IIC的区别三、变量的声明和定义区别四、static在C和C中的区别五、串口总线空闲时候的电平状态总结 前言 本篇文章继续讲解嵌入式笔试面试刷题&#xff0c;希望大家坚持跟…...

【Docker】Dockerfile构建镜像

一、编写Dockerfile文件 编写镜像需要的运行环境&#xff08;Linux、java等&#xff09;&#xff0c; Dockerfile文件内容如下&#xff1a; # 使用官方的 Ubuntu 16.04 镜像作为基础镜像 FROM ubuntu:16.04# 更新包列表 RUN apt-get update# 安装所需的软件包 RUN apt-get ins…...

fota升级,可卸载apk也进行更新

首先如题目要求 可卸载apk是通过刷机或恢复出厂设置之后执行脚本安装的 然后fota升级后&#xff0c;在判断是否“是第一次刷机和恢复出厂设置”时候会返回false&#xff0c;就导致脚本没有执行。导致apk升级不成功 所以我们要完成这个就是&#xff0c;确定fota什么时候升级完…...

ASP.NET dotnet 3.5 实验室信息管理系统LIMS源码

技术架构&#xff1a;ASP.NET dotnet 3.5 LIMS作为一个信息管理系统&#xff0c;它有着和ERP、MIS之类管理软件的共性&#xff0c;如它是通过现代管理模式与计算机管理信息系统支持企业或单位合理、系统地管理经营与生产&#xff0c;最大限度地发挥现有设备、资源、人、技术的…...

2023!6招玩转 Appium 自动化测试

Appium是个什么鬼 Appium是一个移动端的自动化框架&#xff0c;可用于测试原生应用&#xff0c;移动网页应用和混合型应用&#xff0c;且是跨平台的。可用于IOS和Android以及firefox的操作系统。原生的应用是指用android或ios的sdk编写的应用&#xff0c;移动网页应用是指网页…...

WireShark抓包分析TCP三次握手过程,TCP报文解析

「作者主页」&#xff1a;士别三日wyx 「作者简介」&#xff1a;CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」&#xff1a;对网络安全感兴趣的小伙伴可以关注专栏《网络安全入门到精通》 使用WireShark工具抓取TCP协议三次握手的数据包&am…...

【C语言】指针和数组笔试题解析

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家了解指针和数组笔试题解析&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 1.前言2.一维数组2.字符数组2.12.22.32.42.52.6 1.前言 本篇文章是讲述在不同数…...

Vue的模板语法(下)

一.事件处理 事件修饰符 Vue通过由点(.)表示的指令后缀来调用修饰符&#xff0c; .stop&#xff0c; .prevent&#xff0c;.capture&#xff0c;.self&#xff0c;.once .stop&#xff1a;阻止事件冒泡。当一个元素触发了事件&#xff0c;并且该元素包含嵌套的父元素时&#…...

Zookeeper客户端——I0Itec-zkClient

dubbo使用了zkClient而不是使用zookeeper本身的客户端与zookeeper进行交互&#xff0c;为什么呢&#xff1f; 先看看zookeeper本身自带的客户端的问题。 1&#xff09;ZooKeeper的Watcher是一次性的&#xff0c;用过了需要再注册&#xff1b; 2&#xff09; session的超时后…...

火山引擎 ByteHouse:ClickHouse 如何保证海量数据一致性

背景 ClickHouse是一个开源的OLAP引擎&#xff0c;不仅被全球开发者广泛使用&#xff0c;在字节各个应用场景中也可以看到它的身影。基于高性能、分布式特点&#xff0c;ClickHouse可以满足大规模数据的分析和查询需求&#xff0c;因此字节研发团队以开源ClickHouse为基础&…...

静海网站建设制作/珠海网站建设

说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家! 接着上一篇博客继续往下写 :https://blog.csdn.net/qq_41782425/article/details/85623829 目录 一丶关于在项目中循环导入的问题 二丶日志功能实现 三丶项目数据库设计 四丶数据库迁移 一丶关于…...

wordpress浏览图片失败/百度竞价怎么做效果好

前面一篇文章[Flutter实战1 写一个天气查询的APP]实现了一个显示城市、温度、天气、湿度的界面&#xff0c;但是这个界面只有一个显示的功能&#xff0c;没有任何可交互的地方&#xff0c;本篇文章继续完善查询天气的APP的功能。 先上效果图&#xff1b; 增加两个功能&#xff…...

wordpress 多菜单/百度文库官网入口

procstat当前服务器进程性能参数(所有类型的进程都有)cpu_usage&#xff1a;当前服务器进程cpu的占用率&#xff0c;所有子线程的cpu占用之后&#xff0c;每个核算100%memory_rss&#xff1a;当前服务器进程占用的物理内存cpu_thread当前服务器进程的各个子线程的性能参数(所有…...

庄浪县住房和城乡建设局网站/在线网页编辑平台

本节书摘来自华章计算机《Unity着色器和屏幕特效》一书中的第2章&#xff0c;第2.1节&#xff0c;作者&#xff3b;美&#xff3d;杰米迪恩&#xff08;Jamie Dean&#xff09;&#xff0c;译 周翀&#xff0c;张薇&#xff0c;更多章节内容可以访问云栖社区“华章计算机”公众…...

柳市建设网站/成人职业技能培训学校

CentOS版本网址&#xff1a;http://blog.csdn.net/huchunlinnk/article/details/45038025 一、用镜像自带的。 重点&#xff1a;安装linux虚拟机时&#xff0c;要选上有关php环境的所有选项 Apache相关、MySQL相关及PHP相关 1.启动Apache 在终端下输入以下命令后回车 service h…...

常州做网站公司有哪些/哪里能买精准客户电话

胎压监测 (15分) 小轿车中有一个系统随时监测四个车轮的胎压&#xff0c;如果四轮胎压不是很平衡&#xff0c;则可能对行车造成严重的影响。 taiya.JPG 让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序&#x…...