SpringCloud整合ElasticSearch搜索使用

环境说明

xml 复制代码
ORM:easy-es 2.0.0(opens new window)
ElasticSearch:7.14.0
pigx:5.2
请保持环境如上,ElasticSearch 兼容性较差无法保证其他版本正常整合执行。

快速开始

① 安装 ElasticSearch

bash 复制代码
docker run --name es714 -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -d elasticsearch:7.14.0

② 微服务增加 easy-es 依赖

xml 复制代码
<dependency>
    <groupId>org.dromara.easy-es</groupId>
    <artifactId>easy-es-boot-starter</artifactId>
    <version>2.0.0-beta4</version>
</dependency>

③ 配置文件增加链接配置

yaml 复制代码
spring:
  elasticsearch:
    uris: 127.0.0.1:9200
easy-es:
  address: ${spring.elasticsearch.uris}

示例代码编写

① 创建索引实体

java 复制代码
@Data
@IndexName("document")
public class Document {

	/**
	 * es中的唯一id
	 */
	private String id;

	/**
	 * 文档标题
	 */
	private String title;

	/**
	 * 文档内容
	 */
	private String content;
}

② 创建查询 mapper

java 复制代码
public interface DocumentMapper extends BaseEsMapper<Document> {
}

③ SpringBoot 配置扫描 EsMapper 实现

java 复制代码
@EsMapperScan("com.pig4cloud.pigx.es.mapper")

④ API 调用

java 复制代码
public void testCreateIndex() {
    // 测试创建索引,框架会根据实体类及字段上加的自定义注解一键帮您生成索引。需要确保索引托管模式处于manual手动挡(默认处于此模式),若为自动挡则会冲突。
    boolean success = documentMapper.createIndex();
}

public void testInsert() {
    // 测试插入数据
    Document document = new Document();
    document.setTitle("老汉");
    document.setContent("推*技术过硬");
    int successCount = documentMapper.insert(document);
}

public void testSelect() {
    // 测试查询,写法和MP一样,可以用链式,也可以非链式,根据使用习惯灵活选择即可。
    String title = "老汉";
    Document document = EsWrappers.lambdaChainQuery(documentMapper)
            .eq(Document::getTitle, title)
            .one();
    System.out.println(document);
}

高级用法

Easy-Es(简称 EE)是一款基于 ElasticSearch(简称 Es)官方提供的 RestHighLevelClient 打造的 ORM 开发框架,在 RestHighLevelClient 的基础上,只做增强不做改变,为简化开发、提高效率而生。您如果有用过 Mybatis-Plus(简称 MP),那么您基本可以零学习成本直接上手 EE。EE 是 MP 的 Es 平替版,在有些方面甚至比 MP 更简单,同时也融入了更多 Es 独有的功能,助力您快速实现各种场景的开发。

相关推荐
Elasticsearch1 小时前
Elastic Platform 8.18 和 9.0:ES|QL Lookup Joins 功能现已推出,Lucene 10!
elasticsearch
小钊(求职中)3 小时前
ElasticSearch从入门到精通-覆盖DSL操作和Java实战
java·大数据·elasticsearch·搜索引擎·全文检索
mask哥4 小时前
详解最新链路追踪skywalking框架介绍、架构、环境本地部署&配置、整合微服务springcloudalibaba 、日志收集、自定义链路追踪、告警等
java·spring cloud·架构·gateway·springboot·skywalking·链路追踪
Elasticsearch5 小时前
Elastic Observability 9.0/8.18:EDOT 现已正式发布,支持 LLM observability ,以及更多功能
elasticsearch
会游泳的石头6 小时前
Spring Cloud Gateway 如何将请求分发到各个服务
spring cloud
liang89996 小时前
Docker(二):docker常用命令
spring cloud·docker·容器
冼紫菜12 小时前
[特殊字符]实战:使用 Canal + MQ + ES + Redis + XXL-Job 打造高性能地理抢单系统
java·redis·分布式·后端·elasticsearch·rabbitmq·全文检索
程序员沉梦听雨21 小时前
【Elasticsearch】入门篇
大数据·elasticsearch·搜索引擎
Gadus_21 小时前
Elasticsearch性能优化实践
大数据·elasticsearch·搜索引擎·性能优化
八股文领域大手子1 天前
如何给GitHub项目提PR(踩坑记录
大数据·elasticsearch·github