elasticsearch使用心得

本文介绍了Elasticsearch中超出常规from/size限制的大数据量查询解决方案,即使用Scroll API,并对比了不同查询方式的特点。此外,还详细解析了多种查询构造方法,包括must、mustNot、should的不同用法及各种查询API的使用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、分页搜索中from/size:

搜索请求一次请求最大量为[10000]。我们的请求量已经超标,因此报错,异常信息提示我们请求大数据量的情况下使用Scroll API。

2、scroll api   可以获取所有的文档信息,而from/size有数量限制

3、must表示必须满足,mustNot表示必须不满足,should表示可有可无

4、.setFilter(FilterBuilders.rangeFilter("age").from(12).to(18)) :

在这里"age"是要查询的field, 后面的数字是查询的条件范围

5、QueryBuilders.idsQuery().ids("1", "2");  表示通过ID来查询

6、

.setQuery(QueryBuilders.matchQuery("name", "tom"))//指定查询条件,这里不支持通配符 * ?
.setQuery(QueryBuilders.matchAllQuery())//查询所有
.setQuery(QueryBuilders.multiMatchQuery("tom", "name","title"))//支持一个值同时匹配多个字段 等价于SQL语句,就是,where name=tom or title=tom 
.setQuery(QueryBuilders.queryStringQuery("name:to?"))//queryStringQuery查询?匹配一个  *匹配多个
 
7、termQuery 是精确匹配,matchQuery 模糊匹配
8、

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值