Spring Boot如何集成Elasticsearch模块实现简单查询功能
导读:本文共3730.5字符,通常情况下阅读需要12分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 背景项目中我们经常会用搜索功能,普通的搜索我们可以用一个SQL的like也能实现匹配,但是搜索的核心需求是全文匹配,对于全文匹配,数据库的索引是根本派不上用场的,那只能全表扫描。全表扫描的速度已经非常慢了,还需要在每条记录上做全文匹配,一个字一个字的比对,导致查询的数据更慢。所以,使用数据来做搜索,性能上完全没法满足要求。系统集成引入jar包<depend... ...
目录
(为您整理了一些要点),点击可以直达。项目中我们经常会用搜索功能,普通的搜索我们可以用一个SQL的like也能实现匹配,但是搜索的核心需求是全文匹配,对于全文匹配,数据库的索引是根本派不上用场的,那只能全表扫描。全表扫描的速度已经非常慢了,还需要在每条记录上做全文匹配,一个字一个字的比对,导致查询的数据更慢。所以,使用数据来做搜索,性能上完全没法满足要求。
注意:不同的ES版本,引入jar包和配送属性文件的方式不同,本文采用的是Spring Boot 2.2+Elasticsearch7.0的版本。
说明:
indexName:索引的名称
createIndex:ture表示如果不存在,则创建
@Id:索引id
@Field:type字段的类型,format:查询出时间格式化类型。
说明:集成ElasticsearchRepository接口,采用的是JPA的方式实现,JPA默认提供了相关的接口实现。
Elasticsearch的实现分为基础查询和DSL查询。
基础查询主要包含的CRUD查询,以及一些模糊、范围查询等。
说明:date类型传入的参数为long类型。
修改与新增基本相同,唯一区别为:请求参数传入的Id,如果存在则为修改,否则为新增。
说明:
totalPages:总页数
totalElements:总记录数
说明:模糊查询通过findByxxlike
范围查询通常是指>、< >= <=等
说明:范围查询通过findByxxGreaterThanEqual
大于:GreaterThan
大于等于:GreaterThanEqual
小于:LessThan
小于等于:LessThanEqual
Spring Boot如何集成Elasticsearch模块实现简单查询功能的详细内容,希望对您有所帮助,信息来源于网络。