详解Spring Data Jpa 模糊查询的正确用法
作者:那年初二 发布时间:2022-03-28 15:07:50
标签:Spring,Data,Jpa
模糊查询
Spring Data Jpa的使用可以减少开发者对sql语句的编写,甚至完全不需要编写sql语句。但是,开发过程中总会遇到各种复杂的场景以及大大小小的坑。
今天项目中某个功能模块需要用到模糊查询。原生sql中模糊查询关键字‘Like',而Spring Data Jpa的Repository接口中恰恰也有实体字段对应的Like。但是,如果直接使用它,那么恭喜你,你幸运地掉坑了。
Spring Data Jpa 模糊查询正确用法
首先,我们先创建一个实体用来存储我们的数据
/**
* 实体
*
* @author chentai
* @date 18/04/22
*/
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
public class ExampleEntity{
@Id
@GeneratedValue(generator = "uuid")
@GenericGenerator(name = "uuid", strategy = "uuid")
private String Id ;
private String username;
private String deviceNames;
}
接着,创建我们实体对应的Repository接口
/**
* @author chentai
* @date 18/04/22
*/
@Repository
public interface ExampleRepository extends CrudRepository<ExampleEntity, String> {
/**
* 模糊查询正确用法
* 其中username不支持模糊查询,deviceNames支持模糊查询
*
* @param deviceNames 模糊查询deviceNames
* @param username 用户名称
* @return {@link List<ExampleEntity>}
*/
List<ExampleEntity> findAllByDeviceNamesContainingAndUsername(String deviceNames,String username);
/**
* 模糊查询错误用法
* 其中username不支持模糊查询,deviceNames支持模糊查询
*
* @param deviceNames 模糊查询deviceNames
* @param username 用户名称
* @return {@link List<ExampleEntity>}
*/
List<ExampleEntity> findAllByDeviceNamesLikeAndUsername(String deviceNames,String username);
}
最后,在测试类中测试ExampleRepository中的两个方法,(测试结果暂不展示)发现findAllByDeviceNamesLikeAndUsername方法并没有正确查询到我们想要的结果,得到的结果是精确查询的结果。而findAllByDeviceNamesContainingAndUsername得到了我们想要的模糊查询的结果。
总结
如果想要在项目中不编写sql原生语句的情况下使用模糊查询,请使用Containing关键字,而非想当然的认为原生使用Like关键字,JPA中也是使用Like关键字。
来源:https://www.jianshu.com/p/4960d2705b4e


猜你喜欢
- 今天把Android Studio 升级到4.1版本,发现GsonFormat没有了,网上有的解决办法从https://plugins.je
- 23种设计模式第十二篇:java模版方法模式定义:定义一个操作中算法的框架,而将一些步骤延迟到子类中,使得子类可以不改变算法的结构即可重定义
- 1. Android中文件读写的原理: (1).所有文件的储存都是字节的储存。 (2).在磁盘上保留的并不是文件的字符而是先把字符编码成字节
- 接触了这么久的View,总不能一直停留在View里,现在开始呢,就要学习一个新的知识点:SurfaceView,实际上SurfaceView
- 如何实现封装可以分为两步:第一步:将类的变量声明为private。第二步:提供公共set和get方法来修改和获取变量的值。代码展示publi
- ArrayList的构造方法(前置知识)可快速过一些基本成员变量:// 默认初始大小private static final int DEF
- 现象在日志配置文件 logback-spring.xml 中,无论怎么修改级别,mybatis 的 sql 日志都会打印出来。原因在 app
- 其实本没有没打算写这篇的,但还是要写一下写这篇博客的起因是因为,现在呆着的这家公司居然没有统一的API返回格式?,询问主管他居然告诉我用HT
- 项目中遇到springBoot+docker需要配置不同环境变量的问题,做个简单的总结:1.开发环境ide中启动项目可以通过ide的环境变量
- 实例如下://图片到byte数组 public byte[] image2byte(String path){ byte[] d
- Javaweb获取表单数据的几种方式一、通过键值对的形式获取表单数据getParameter(String name):通过key,返回一个
- 什么是Spring BootSpring Boot 是由 Pivotal 团队提供的全新框架,其设计目的是用来简化新 Spring 应用的初
- 将map集合存数据与取出数据全部放在一个类MapTest中,方便阅读与查看随便创建一个包,在包中新建一个class文件,(也可以不建包,直接
- 本文实例讲述了Android中SeekBar和RatingBar用法。分享给大家供大家参考,具体如下:什么是SeekBar?可以拖动的进度条
- 前言:在日常的代码开发中,此处相信每个开发人员对代码质量都是高要求,有自己的一套代码规范,但是我们不是单独作战,往往大家都是团队作战,人是最
- 流程引擎对象和其配置对象都是activiti的核心对象一、activiti的简单使用流程activiti在工作时,一般有以下几个步骤:创建一
- 一、获取当前时间, 格式为: yyyy-mm-dd hh-mm-ss
- 今天写项目突然出现了无法启动Gradle的bug,如下图然后就看了log日志:这个问题是我第一次看见,然后就开始了各种百度,有说需要在And
- 本文实例讲述了C#清除WebBrowser中Cookie缓存的方法。分享给大家供大家参考,具体如下:最近用C#写一个程序,用一个窗体中的We
- 效果明细用Popup实现的,录gif时,Popup显示不出来,不知道为什么,所以静态图凑合看吧大体思路图表使用Arc+Popup实现图表分为