spring elasticsearch 按条件删除_SpringBoot2 高级案例(08):整合 ElasticSearch框架,实现高性能搜索引擎...
一、安装和简介
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框架,实现高性能搜索引擎...相关推荐
- 中间省略_SpringBoot2 高级案例(03): 整合sharding-jdbc中间件,实现数据分库分表
一.水平分割 1.水平分库 1).概念: 以字段为依据,按照一定策略,将一个库中的数据拆分到多个库中. 2).结果 每个库的结构都一样:数据都不一样: 所有库的并集是全量数据: 2.水平分表 1).概 ...
- jwt获取token_SpringBoot2 高级案例(09): 整合 JWT 框架,解决Token跨域验证问题
一.传统Session认证 1.认证过程 1.用户向服务器发送用户名和密码. 2.服务器验证后在当前对话(session)保存相关数据. 3.服务器向返回sessionId,写入客户端 Cookie. ...
- spring elasticsearch 按条件删除_实战:项目数据源转为Elasticsearch
原本项目是基于MYSQL的,现因需求将其转换为MYSQL+Elasticsearch,MYSQL的ORM使用的是Spring Data Jpa,Mybatis的转换与其类似,有人看再更 先看原项目 原 ...
- spring elasticsearch 按条件删除_Elasticsearch系列之Query DSL
1 前言 我们先通过阅读官方文档,了解一下什么是 Query DSL . 1.1 Query DSL Elasticsearch provides a full Query DSL (Domain S ...
- mybatisplus代码生成连接池_SpringBoot2 高级案例(15): 配置多数据源,整合MybatisPlus增强插件...
一.项目案例简介 1.多数据简介 实际的项目中,经常会用到不同的数据库以满足项目的实际需求.随着业务的并发量的不断增加,一个项目使用多个数据库:主从复制.读写分离.分布式数据库等方式,越来越常见. 2 ...
- SpringBoot2.0 整合 ElasticSearch框架,实现高性能搜索引擎
本文源码 GitHub:知了一笑 https://github.com/cicadasmile/spring-boot-base 一.安装和简介 ElasticSearch是一个基于Lucene的搜索 ...
- spring日志报错提醒_Spring Boot 2.x : 整合日志框架 Log4j2
日志框架概述 在一个 web 项目建设中,如果说第一件事是 Spring 框架的搭建,那么第二件事就是日志框架的搭建,线上 web 项目的日志可能是我们了解项目运行的唯一方式. 常用日志框架 java ...
- 【十九】springboot整合ElasticSearch实战(万字篇)
本章开始学习springboot整合ElasticSearch 7.X版本并通过小demo实现基本的增删改查.实现如下案例: 1.当向数据新增一个商品信息时,同时向rabbitMQ发起消息(异步实现) ...
- 整合Elasticsearch实现商品搜索
整合Elasticsearch实现商品搜索 本文主要讲解mall整合Elasticsearch的过程,以实现商品信息在Elasticsearch中的导入.查询.修改.删除为例. 项目使用框架介绍 El ...
最新文章
- R语言ggplot2可视化使用不连续的y轴、中断的Y轴来可视化数值分布差异很大的数据实战:把数据轴分为两个区间或者多个区间来匹配不同区间数据的可视化(因为有的数据可能10附近,有的数值可能1W附近)
- Java 8 - Lambda从兴趣盎然到索然无味
- 0009:err:module:__wine_process_init failed to load xxx
- 大楼(bzoj 2165)
- 恒驰机器人_2545台机器人,1分钟造1辆车,恒大许家印的智能造车工厂首次曝光...
- df python 增加数据_美国确诊超100万!教你用Python画出全球疫情动态图(附数据下载)...
- git-osc自己定义控件之:CircleImageView
- 差分硬盘的merge(合并差异)实验分析
- python新浪api_python调用新浪微博API项目实践
- 解决wine中文显示为方框的方法
- DxO PhotoLab 3 for Mac(照片后期处理软件)
- 【Android自定义控件】仿京东首页的京东快报,自动向上滚动的广告条
- 海外版华为手机安装谷歌框架(也适用于国内任意机型)
- Android应用停用
- 静态资源压缩-nginx缓存问题
- 快速实现安卓输入法!
- netty权威指南目录
- 高通Q888内核源码分析--概述篇
- [零刻]EQ12EQ12Pro安装OpenWRT软路由教程
- jmeter打开bat文件闪退