Elastic Search 安装使用

1.安装

官方下载地址:www.elastic.co/cn/download...

解压文件,然后创建一个es 用户,给用户文件权限

bash 复制代码
chown -R es /opt/elasticsearch-9.2.2

修改配置文件,添加ES_JAVA_HOME

bash 复制代码
vim /etc/profile

export ES_JAVA_HOME="/opt/elasticsearch-9.2.2/jdk"

souce /etc/profile

切换用户

复制代码
su es

启动es

bash 复制代码
./bin/elasticsearch -d

//设置密码 用户默认是:elastic

/opt/elasticsearch-9.2.2/bin/elasticsearch-reset-password -u elastic -i

浏览器可以使用插件 Multi Elasticsearch Heads,添加地址,测试连接

2.使用

2.1 创建索引

text和keyword的区别

text keyword
分词
存储 多个token 字符串
模糊搜索 支持 不支持
排序 不支持 支持
聚合 不支持 支持
less 复制代码
CreateIndexRequest request = CreateIndexRequest.of(c -> c .index("users") // 索引名称 
    .mappings(m -> m .properties("name", p -> p.text(t -> t)) //text类型 
    .properties("age", p -> p.integer(i -> i)) //数字类型 
    .properties("email", p -> p.keyword(k -> k)) // keyword类型 ) ); 
CreateIndexResponse response = client.indices().create(request);

2.2 增加

less 复制代码
IndexResponse response = client.index(i -> i .index("users") .id("1") 
    .document(Map.of( "name", "张三", "age", 18, "email", "zhangsan@xxx.com" )) );

2.3 更新

less 复制代码
UpdateResponse<Map> updateResponse = client.update(u -> u 
    .index("users") 
    .id("1") .doc(Map.of("age", 29)), Map.class );

2.4 删除

ini 复制代码
DeleteResponse response = client.delete(d -> d .index("users") .id("1") );

2.5 查询

条件查询
less 复制代码
SearchResponse<Map> search = client.search(s -> s 
    .index("users") 
    .query(q -> q 
    .match(m -> m .field("name") .query("张三") ) ), Map.class );
range 范围查询
less 复制代码
SearchResponse<Map> rangeSearch = client.search(s -> s 
    .index("users") 
    .from(0).size(10) 
    .query(q -> q 
    .range(r -> r .field("age") .gte(JsonData.of(20)) .lte(JsonData.of(30)) ) ),
    Map.class );
bool 多条件查询

must ==> and

must_not ==> 都不满足

should ==> or

filter ==> 满足条件

match ==> 全文索引

less 复制代码
SearchResponse<Map> boolSearch = client.search(s -> s 
    .index("users") 
    .query(q -> q 
    .bool(b -> b 
    .must(m -> m.match(ma -> ma.field("name").query("张三"))) 
    .filter(f -> f.range(r -> r.field("age").gte(20))) ) ), Map.class );
相关推荐
IT_陈寒6 分钟前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端
MekoLi2921 分钟前
Spring AI 与 LangChain4j 从入门到精通:Java 后端开发者的 AI 实战手册
后端·面试
树獭叔叔25 分钟前
从RLHF到PPO:让AI学会说人话
后端·aigc·openai
Meepo_haha27 分钟前
创建Spring Initializr项目
java·后端·spring
Memory_荒年29 分钟前
SpringBoot事务源码深度游:从注解到数据库的“奇幻漂流”
java·后端·spring
编码忘我32 分钟前
为什么要用SpringBoot
java·后端
Memory_荒年41 分钟前
SpringBoot事务:从“一键开关”到“踩坑大全”的生存指南
java·后端·spring
PFinal社区_南丞1 小时前
一文讲透 .trae 文件夹 - Trae IDE 配置指南和最佳实践
后端
段小二1 小时前
Spring AI Agent 完整实战:Function Calling + RAG + Memory + SafeGuard 构建机票助手
后端
编码忘我1 小时前
Spring源码又看了一遍
后端