黑马程序员技术交流社区

标题: 【郑州校区】Elasticsearch 学习笔记之过滤器 [打印本页]

作者: 我是楠楠    时间: 2018-10-19 15:12
标题: 【郑州校区】Elasticsearch 学习笔记之过滤器
【郑州校区】Elasticsearch 学习笔记之过滤器

我们已经介绍了如何使用不同的条件和查询来构建查询并搜索数据。我们还熟知了评分,它告诉我们在给定的查询中,哪些文档更重要以及查询文本如何影响排序。然而,有时我们可能要在不影响最后分数的情况下,选择索引中的某个子集,这就要使用过滤器。
如果可以,应该尽可能使用过滤器。过滤器不影响评分,而得分计算让搜索变得复杂,而且需要CPU资源。另一方面,过滤是一种相对简单的操作。由于过滤应用在整个索引的内容上,过滤的结果独立于找到的文档,也独立于文档之间的关系。过滤器很容易被缓存,从而进一步提高过滤查询的整体性能。
1.1. 范围过滤器
[AppleScript] 纯文本查看 复制代码
/**范围过滤器*/
        @Test
        public void testRangeQuery() throws Exception{
                SearchResponse searchResponse = client.prepareSearch("blog").setTypes("article")
                                .setPostFilter(QueryBuilders.rangeQuery("id").from(1).to(2))
                                .get();
                SearchHits hits = searchResponse.getHits();//获取数据的结果集对象,获取命中次数
                // 显示数据
                this.searchValue(hits);
                //关闭
                client.close();
        }

1.2. 布尔过滤器
[AppleScript] 纯文本查看 复制代码
/**bool过滤器*/
        @Test
        public void testFilter() throws Exception{
                SearchResponse searchResponse = client.prepareSearch("blog").setTypes("article")
                                .setPostFilter(QueryBuilders.boolQuery().must(QueryBuilders.termQuery("title", "搜索"))
                                                .must(QueryBuilders.termQuery("content", "搜索")))
                                .get();
                SearchHits hits = searchResponse.getHits();//获取数据的结果集对象,获取命中次数
                // 显示数据
                this.searchValue(hits);
                //关闭
                client.close();
        }

添加缓存:
    过滤器的缓存
关于过滤器最后要提到的是缓存。缓存加速了使用过滤器的查询,代价是第一次执行过滤器时的内存成本和查询时间。因此,缓存的最佳选择是那些可以重复使用的过滤器,例如,经常会使用并包括参数值的那些。
在范围过滤器中添加缓存
[AppleScript] 纯文本查看 复制代码
/**范围过滤器*/
        @Test
        public void testRangeQuery() throws Exception{
                SearchResponse searchResponse = client.prepareSearch("blog").setTypes("article")
                                .setPostFilter(QueryBuilders.rangeQuery("id").from(1).to(2))
.setRequestCache(true)//放置到缓存
                                .get();

                SearchHits hits = searchResponse.getHits();//获取数据的结果集对象,获取命中次数
                // 显示数据
                this.searchValue(hits);
                //关闭
                client.close();
        }

传智播客·黑马程序员郑州校区地址
河南省郑州市 高新区长椿路11号大学科技园(西区)东门8号楼三层
联系电话 0371-56061160/61/62
来校路线  地铁一号线梧桐街站A口出






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2