一、安装和简介

ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。

ElasticSearch 安装教程

二、与SpringBoot2整合

1、核心依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId><version>${spring-boot.version}</version>
</dependency>

2、配置文件

spring:application:name: ware-elastic-searchdata:elasticsearch:# 默认 elasticsearchcluster-name: elasticsearch# 9200作为Http协议,主要用于外部通讯# 9300作为Tcp协议,jar之间就是通过tcp协议通讯cluster-nodes: 192.168.72.130:9300

3、实体类配置

  • Document 配置
加上了@Document注解之后,默认情况下这个实体中所有的属性都会被建立索引、并且分词。
indexName索引名称 理解为数据库名 限定小写
type 理解为数据库的表名称
shards = 5 默认分区数
replicas = 1 每个分区默认的备份数
refreshInterval = "1s" 刷新间隔
indexStoreType = "fs"  索引文件存储类型

  • 代码块
@Document(indexName = "requestlogindex",type = "requestlog")
public class RequestLog {//Id注解Elasticsearch里相应于该列就是主键,查询时可以使用主键查询@Idprivate Long id;private String orderNo;private String userId;private String userName;private String createTime;
}

4、数据交互层

实现ElasticsearchRepository接口。

public interface RequestLogRepository
extends ElasticsearchRepository<RequestLog,Long> {}

5、演示案例

数据增加,修改,查询,排序,多条件查询。

@Service
public class RequestLogServiceImpl implements RequestLogService {@Resourceprivate RequestLogRepository requestLogRepository ;@Overridepublic String esInsert(Integer num) {for (int i = 0 ; i < num ; i++){RequestLog requestLog = new RequestLog() ;requestLog.setId(System.currentTimeMillis());requestLog.setOrderNo(DateUtil.formatDate(new Date(),DateUtil.DATE_FORMAT_02)+System.currentTimeMillis());requestLog.setUserId("userId"+i);requestLog.setUserName("张三"+i);requestLog.setCreateTime(DateUtil.formatDate(new Date(),DateUtil.DATE_FORMAT_01));requestLogRepository.save(requestLog) ;}return "success" ;}@Overridepublic Iterable<RequestLog> esFindAll (){return requestLogRepository.findAll() ;}@Overridepublic String esUpdateById(RequestLog requestLog) {requestLogRepository.save(requestLog);return "success" ;}@Overridepublic Optional<RequestLog> esSelectById(Long id) {return requestLogRepository.findById(id) ;}@Overridepublic Iterable<RequestLog> esFindOrder() {// 用户名倒序// Sort sort = new Sort(Sort.Direction.DESC,"userName.keyword") ;// 创建时间正序Sort sort = new Sort(Sort.Direction.ASC,"createTime.keyword") ;return requestLogRepository.findAll(sort) ;}@Overridepublic Iterable<RequestLog> esFindOrders() {List<Sort.Order> sortList = new ArrayList<>() ;Sort.Order sort1 = new Sort.Order(Sort.Direction.ASC,"createTime.keyword") ;Sort.Order sort2 = new Sort.Order(Sort.Direction.DESC,"userName.keyword") ;sortList.add(sort1) ;sortList.add(sort2) ;Sort orders = Sort.by(sortList) ;return requestLogRepository.findAll(orders) ;}@Overridepublic Iterable<RequestLog> search() {// 全文搜索关键字/*String queryString="张三";QueryStringQueryBuilder builder = new QueryStringQueryBuilder(queryString);requestLogRepository.search(builder) ;*//** 多条件查询*/QueryBuilder builder = QueryBuilders.boolQuery()// .must(QueryBuilders.matchQuery("userName.keyword", "历张")) 搜索不到.must(QueryBuilders.matchQuery("userName", "张三")) // 可以搜索.must(QueryBuilders.matchQuery("orderNo", "20190613736278243"));return requestLogRepository.search(builder) ;}
}

三、源代码地址

GitHub地址:知了一笑
https://github.com/cicadasmile/middle-ware-parent
码云地址:知了一笑
https://gitee.com/cicadasmile/middle-ware-parent

spring elasticsearch 按条件删除_SpringBoot2 高级案例(08):整合 ElasticSearch框架,实现高性能搜索引擎...相关推荐

  1. 中间省略_SpringBoot2 高级案例(03): 整合sharding-jdbc中间件,实现数据分库分表

    一.水平分割 1.水平分库 1).概念: 以字段为依据,按照一定策略,将一个库中的数据拆分到多个库中. 2).结果 每个库的结构都一样:数据都不一样: 所有库的并集是全量数据: 2.水平分表 1).概 ...

  2. jwt获取token_SpringBoot2 高级案例(09): 整合 JWT 框架,解决Token跨域验证问题

    一.传统Session认证 1.认证过程 1.用户向服务器发送用户名和密码. 2.服务器验证后在当前对话(session)保存相关数据. 3.服务器向返回sessionId,写入客户端 Cookie. ...

  3. spring elasticsearch 按条件删除_实战:项目数据源转为Elasticsearch

    原本项目是基于MYSQL的,现因需求将其转换为MYSQL+Elasticsearch,MYSQL的ORM使用的是Spring Data Jpa,Mybatis的转换与其类似,有人看再更 先看原项目 原 ...

  4. spring elasticsearch 按条件删除_Elasticsearch系列之Query DSL

    1 前言 我们先通过阅读官方文档,了解一下什么是 Query DSL . 1.1 Query DSL Elasticsearch provides a full Query DSL (Domain S ...

  5. mybatisplus代码生成连接池_SpringBoot2 高级案例(15): 配置多数据源,整合MybatisPlus增强插件...

    一.项目案例简介 1.多数据简介 实际的项目中,经常会用到不同的数据库以满足项目的实际需求.随着业务的并发量的不断增加,一个项目使用多个数据库:主从复制.读写分离.分布式数据库等方式,越来越常见. 2 ...

  6. SpringBoot2.0 整合 ElasticSearch框架,实现高性能搜索引擎

    本文源码 GitHub:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.安装和简介 ElasticSearch是一个基于Lucene的搜索 ...

  7. spring日志报错提醒_Spring Boot 2.x : 整合日志框架 Log4j2

    日志框架概述 在一个 web 项目建设中,如果说第一件事是 Spring 框架的搭建,那么第二件事就是日志框架的搭建,线上 web 项目的日志可能是我们了解项目运行的唯一方式. 常用日志框架 java ...

  8. 【十九】springboot整合ElasticSearch实战(万字篇)

    本章开始学习springboot整合ElasticSearch 7.X版本并通过小demo实现基本的增删改查.实现如下案例: 1.当向数据新增一个商品信息时,同时向rabbitMQ发起消息(异步实现) ...

  9. 整合Elasticsearch实现商品搜索

    整合Elasticsearch实现商品搜索 本文主要讲解mall整合Elasticsearch的过程,以实现商品信息在Elasticsearch中的导入.查询.修改.删除为例. 项目使用框架介绍 El ...

最新文章

  1. R语言ggplot2可视化使用不连续的y轴、中断的Y轴来可视化数值分布差异很大的数据实战:把数据轴分为两个区间或者多个区间来匹配不同区间数据的可视化(因为有的数据可能10附近,有的数值可能1W附近)
  2. Java 8 - Lambda从兴趣盎然到索然无味
  3. 0009:err:module:__wine_process_init failed to load xxx
  4. 大楼(bzoj 2165)
  5. 恒驰机器人_2545台机器人,1分钟造1辆车,恒大许家印的智能造车工厂首次曝光...
  6. df python 增加数据_美国确诊超100万!教你用Python画出全球疫情动态图(附数据下载)...
  7. git-osc自己定义控件之:CircleImageView
  8. 差分硬盘的merge(合并差异)实验分析
  9. python新浪api_python调用新浪微博API项目实践
  10. 解决wine中文显示为方框的方法
  11. DxO PhotoLab 3 for Mac(照片后期处理软件)
  12. 【Android自定义控件】仿京东首页的京东快报,自动向上滚动的广告条
  13. 海外版华为手机安装谷歌框架(也适用于国内任意机型)
  14. Android应用停用
  15. 静态资源压缩-nginx缓存问题
  16. 快速实现安卓输入法!
  17. netty权威指南目录
  18. 高通Q888内核源码分析--概述篇
  19. [零刻]EQ12EQ12Pro安装OpenWRT软路由教程
  20. jmeter打开bat文件闪退

热门文章

  1. python基础学习1-内置函数
  2. 快速入门虚拟机+linux安装(附带视频)
  3. 计算机网络——TCP/IP参考模型和五层参考模型
  4. python-scrapy爬虫框架
  5. Leetcode--881. 救生艇
  6. html与js与mysql_WebView加载html与JS交互
  7. 下取整函数的含义_取整函数解读
  8. 易语言mysql锁表_MySQL的3种锁定机制
  9. AndroidStudio 3.4更新了啥?(转载)
  10. java web的友好页面_JavaWeb 之 由 Tomcat 展示友好的错误信息页面