Spring Boot 集成Elasticsearch模块实现简单查询功能
作者:剑圣无痕 发布时间:2022-09-05 06:31:31
背景
项目中我们经常会用搜索功能,普通的搜索我们可以用一个SQL的like也能实现匹配,但是搜索的核心需求是全文匹配,对于全文匹配,数据库的索引是根本派不上用场的,那只能全表扫描。全表扫描的速度已经非常慢了,还需要在每条记录上做全文匹配,一个字一个字的比对,导致查询的数据更慢。所以,使用数据来做搜索,性能上完全没法满足要求。所以我们需要采用Elasticsearch来实现检索,本文将介绍SpringBoot如何集成Elasticsearch?
系统集成
引入jar包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
application.yml文件中添加ES配置
elasticsearch:
rest:
uris: http://localhost:9200
注意:不同的ES版本,引入jar包和配送属性文件的方式不同,本文采用的是Spring Boot 2.2+Elasticsearch7.0的版本。
创建文档实体
@Document(indexName = "product", createIndex = true)
public class Product implements Serializable
{
private static final long serialVersionUID = -2408117939493050954L;
@Id
@Field(type = FieldType.Text)
private String id;
@Field(type = FieldType.Text)
private String skuNo;
@Field(type = FieldType.Text)
private String tilte;
@Field(type = FieldType.Double)
private BigDecimal price;
@Field(type = FieldType.Date, format = DateFormat.basic_date_time)
private Date createDate;
}
说明:
indexName:索引的名称
createIndex:ture表示如果不存在,则创建
@Id:索引id
@Field:type字段的类型,format:查询出时间格式化类型。
接口实现
public interface EsProductRepository extends ElasticsearchRepository<Product,String>
{
List<Product> findByskuNoAndTilte(String sku,String title);
}
说明:集成ElasticsearchRepository接口,采用的是JPA的方式实现,JPA默认提供了相关的接口实现。
具体实现
Elasticsearch的实现分为基础查询和DSL查询。
基础查询
基础查询主要包含的CRUD查询,以及一些模糊、范围查询等。
新增文档
请求参数
{
"id":"5",
"skuNo":"sku0005",
"tilte":"红楼梦",
"price":"93.37",
"createDate":"1514736000000"
}
说明:date类型传入的参数为long类型。
Controller实现
@PostMapping("/addProduct")
public Result addProduct(@RequestBody Product product)
{
esProductRepository.save(product);
Result result = new Result();
result.setCode(200);
result.setData(product);
return result;
}
返回结果
{
"data": {
"id": "5",
"skuNo": "sku0005",
"tilte": "红楼梦",
"price": 93.37,
"createDate": "2017-12-31T16:00:00.000+00:00"
},
"code": 200,
"msg": null
}
修改文档
修改与新增基本相同,唯一区别为:请求参数传入的Id,如果存在则为修改,否则为新增。
通过id查询文档信息
Controller实现
@GetMapping("/getProductById")
public Result getProductById(@RequestParam String id) {
Optional<Product> product = esProductRepository.findById(id);
return Result.success(product);
}
删除文档
Controller实现
@PostMapping("/deleteById")
public Result deleteById(@RequestParam String id)
{
return Result.success(null);
}
分页查询
Controller实现
@GetMapping("/getPageList")
public Result getPageList(@RequestParam int pageNum,@RequestParam int pageSize)
{
Pageable pageable = PageRequest.of(pageNum, pageSize);
Page<Product> pageList= esProductRepository.findAll(pageable);
return Result.success(pageList);
}
返回结果
{
"data": {
"content": [
{
"id": "1",
"skuNo": "p0001",
"tilte": null,
"price": 99.9,
"createDate": null
},
{
"id": "3",
"skuNo": "p0002",
"tilte": null,
"price": 99.8,
"createDate": null
},
{
"id": "4",
"skuNo": "p0004",
"tilte": null,
"price": 110,
"createDate": null
},
{
"id": "L1zuVYEBuycvlc7eiQ7_",
"skuNo": "sku0001",
"tilte": "水浒传",
"price": 93.37,
"createDate": "1970-01-01T05:37:00.611+00:00"
},
{
"id": "5",
"skuNo": "sku0005",
"tilte": "红楼梦",
"price": 93.37,
"createDate": "2017-12-31T16:00:00.000+00:00"
}
],
"pageable": {
"sort": {
"sorted": false,
"unsorted": true,
"empty": true
},
"offset": 0,
"pageSize": 5,
"pageNumber": 0,
"paged": true,
"unpaged": false
},
"aggregations": null,
"scrollId": null,
"maxScore": 1.0,
"totalPages": 1,
"totalElements": 5,
"number": 0,
"size": 5,
"sort": {
"sorted": false,
"unsorted": true,
"empty": true
},
"numberOfElements": 5,
"first": true,
"last": true,
"empty": false
},
"code": 200,
"msg": null
}
说明:
totalPages:总页数
totalElements:总记录数
模糊查询
Controller实现
@GetMapping("/findByTilteLike")
public Result findByTilteLike(@RequestParam String key) {
List<Product> products = esProductRepository.findByTilteLike(key);
return Result.success(products);
}
说明:模糊查询通过findByxxlike
范围查询
范围查询通常是指>、< >= <=等
Controller实现
@GetMapping("/findByPriceGreaterThanEqual")
public Result findByPriceGreaterThanEqual(@RequestParam Double price) {
List<Product> products = esProductRepository.findByPriceGreaterThanEqual(price);
return Result.success(products);
}
说明:范围查询通过findByxxGreaterThanEqual
大于:GreaterThan
大于等于:GreaterThanEqual
小于:LessThan
小于等于:LessThanEqual
来源:https://juejin.cn/post/7108331484494184455
猜你喜欢
- 一、遇到一个问题1、读取CSV文件package com.guor.demo.charset;import java.io.Buffered
- Java环境部署下载所需软件和依赖安装 jdk路径可选别的盘。但是指向时得注意我自己时装在 F 盘的,在f盘里新建文件夹 Java,Java
- 目录前言:对文章出现的一些名词进行解释一、插入排序1.基本思想2.直接插入排序3.希尔排序(缩小增量排序)二、选择排序1.基本思想2.直接选
- 1 二叉排序树的概述本文没有介绍一些基础知识。对于常见查找算法,比如顺序查找、二分查找、插入查找、斐波那契查找还不清楚的,可以看这篇文章:常
- 导语:有些时候我们所需要查询的数据量比较大,但是jvm内存又是有限制的,数据量过大会导致内存溢出。这个时候就可以使用流式查询,数据一条条的返
- 项目地址: GITHUB (本地下载)java mybatis 多表查询简介实现简单的实体类操作多表, 首先你的项目是
- 1.比较两个字符串时使用“==”还是equals()方法?当然是equals方法。“==”测试的是两个对象的引用是否相同,而equals()
- java常量池技术java中常量池技术说的通俗点就是java级别的缓存技术,方便快捷的创建一个对象。当需要一个对象时,从池中去获取(如果池中
- MyBatis的前身叫iBatis,本是apache的一个开源项目, 2010年这个项目由apache software foundatio
- 本文实例为大家分享了android实现简易计算器展示的具体代码,供大家参考,具体内容如下效果图:一、如图,首先布局计算器主页显示activi
- Java的动态绑定所谓的动态绑定就是指程执行期间(而不是在编译期间)判断所引用对象的实际类型,根据其实际的类型调用其相应的方法。java继承
- Atomikos是一个为Java平台提供增值服务的并且开源类事务管理器,如果将事务统一注册到Atomikos中,则可以统一管理。常用于后台管
- 简单介绍一下Java中的Excel文件导出功能(基于HttpServletResponse实现下载)首先,引入需要依赖的jar包:<d
- 本文是一个 Spring 扩展支持 SPEL 的简单模式,方便第三方通过 Spring 提供额外功能。简化版方式这种方式可以在任何能获取Ap
- 这篇文章主要介绍了Spring Boot Debug调试过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 1、switch支持String做参数/*** * switch支持字符串做参数 jdk7 * @author huangjiawei */
- 原理解析:利用RandomAccessFile在本地创建一个随机访问文件,文件大小和服务器要下载的文件大小相同。 根据线程的数量(假设有三个
- 1. 对象的创建对象创建的主要流程:1.类加载检查虚拟机遇到一条new指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引
- 代码import javax.mail.internet.InternetAddress;import javax.mail.interne
- Spring Boot 程序优化一、延迟初始化Bean一般在 SpringBoot 中都拥有很多的耗时任务,比如数据库建立连接、初始线程池的