`
kfcman
  • 浏览: 399939 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

elasticsearch和lucene4查询语法比较

 
阅读更多

查询短语在单个字段上:
elasticsearch:

1
2
 QueryStringQueryBuilder queryBuilder = new QueryStringQueryBuilder("汉语词法或其它汉语语言知识进行分词");
 queryBuilder.analyzer("ik").field("title");

lucene4:

1
2
3
 QueryParser qp = new QueryParser(Version.LUCENE_42, "title",  new IKAnalyzer(true));
 qp.setDefaultOperator(QueryParser.AND_OPERATOR);
 Query q = qp.parse("汉语词法或其它汉语语言知识进行分词");

查询短语在多个字段上查找:
elasticsearch:

1
2
 QueryStringQueryBuilder queryBuilder = new QueryStringQueryBuilder("汉语词法或其它汉语语言知识进行分词");
 queryBuilder.analyzer("ik").field("title").field("content");

lucene4:

1
2
3
4
5
6
7
 Analyzer analyzer=new IKAnalyzer(true);
 MultiFieldQueryParser.parse(Version.LUCENE_42, new String[]{"汉语词法或其它汉语语言知识进行分词"},new String[]{"title","content"},analyzer);
//默认在两个字段之间是或关系。如果需要改变两个字段之间的关系,请使用以下方法。
//查询字段必须在title字段,在content字段为或关系
BooleanClause.Occur[] flags = {BooleanClause.Occur.MUST,BooleanClause.Occur.SHOULD};
Analyzer analyzer=new IKAnalyzer(true);
MultiFieldQueryParser.parse(Version.LUCENE_42,"汉语词法或其它汉语语言知识进行分词",new String[]{"title","content"},flags,analyzer);

term query:
elasticsearch:

1
TermQueryBuilder t=new TermQueryBuilder("title", "中国");

lucene4:

1
2
 Term term = new Term("title", "中国");
TermQuery query=new TermQuery(term);

组合查询:
需求:查询在科技频道,体育频道下,文章类型为3,标题和内容包含”全面发展的中国”的文章
elasticsearch:

1
2
3
4
5
6
7
8
9
List<Long> channelids = new ArrayList<Long>();
channelids.add("4");
channelids.add("5");
FilteredQueryBuilder queryBuilder= QueryBuilders.filteredQuery(
                    new QueryStringQueryBuilder("全面发展的中         国").analyzer("ik").field("title").filed("content"), 
                    FilterBuilders.boolFilter()
                    .should(FilterBuilders.termsFilter("channelid", channelids))
                    .must(FilterBuilders.termFilter("model", 4))
                    );

lucene4:

1
2
3
4
5
6
7
8
9
10
11
12
13
Analyzer analyzer=new IKAnalyzer(true);
  Query query =MultiFieldQueryParser.parse(Version.LUCENE_42, new String[]{"全面发展的中国"},new String[]{"title","content"},analyzer);
Term term1 = new Term("channelid", "4");
Term term2 = new Term("channelid", "5");
Term term3 = new Term("model", "4");
 TermQuery q1 = new TermQuery(term1);  
 TermQuery q2 = new TermQuery(term2);  
 TermQuery q3 = new TermQuery(term3);  
 BooleanQuery booleanQuery = new BooleanQuery();  
 booleanQuery.add(q1, BooleanClause.Occur.SHOULD); 
booleanQuery.add(q2, BooleanClause.Occur.SHOULD); 
booleanQuery.add(q3, BooleanClause.Occur.MUST); 
booleanQuery.add(query, BooleanClause.Occur.MUST);

本文固定链接: http://www.chepoo.com/elasticsearch-lucene4-compare-query-syntax.html | IT技术精华网

分享到:
评论

相关推荐

    JAVA使用ElasticSearch查询in和not in的实现方式

    使用Elasticsearch查询in和not in的实现方式可以满足我们各种查询需求,提高我们的开发效率和查询速度。 本文总结了使用Elasticsearch查询in和not in的实现方式,希望对大家的学习或者工作具有一定的参考价值。

    lucene4.4+elasticsearch源码

    《深入理解Lucene 4.4与Elasticsearch:源码剖析与实战探索》 Lucene和Elasticsearch是两个在信息检索和大数据分析领域中不可或缺的重要工具。Lucene作为一个高性能、全文本搜索库,提供了丰富的索引和搜索功能;而...

    tripod:实时文本匹配与Lucene的查询语法兼容

    另外,它兼容lucene语法,可以与即有的基于lucene与elasticsearch的应用无缝整合,即如果采用lucene语法描述客户关注的信息,那么即可以使用Tripod解决实时推送问题,也可以实现从lucene或elasticsear

    Lucene索引和查询

    **Lucene索引和查询** Lucene是Apache软件基金会的开放源码全文搜索引擎库,它提供了文本检索的核心工具,使得开发者能够快速构建自己的搜索应用。本项目中的代码旨在展示如何利用Lucene对多个文件夹下的数据进行...

    ElasticSearch客户端工具

    ElasticSearch客户端工具是用于管理和操作Elasticsearch(ES)集群的重要软件,它们提供了一种直观、高效的方式来查看和管理ES集群的状态、索引、文档以及执行查询和分析任务。这些工具极大地简化了对Elasticsearch...

    ElasticSearch官方测试数据

    Elasticsearch(ES)是一种流行的开源全文搜索引擎,它基于Lucene库构建,被广泛用于大数据分析、日志聚合、实时搜索和索引等场景。官方提供的测试数据集是检验Elasticsearch功能、性能和稳定性的关键资源,可以帮助...

    《ElasticSearch入门到实战》电子书,从入门到进阶实战项目的教程文档,框架SpringBoot框架整合ES.zip

    3. **查询与过滤**:掌握 Elasticsearch 的查询语法,包括匹配查询、范围查询、模糊查询等,以及如何使用过滤器来筛选结果。 4. **聚合分析**:学习如何使用 Elasticsearch 的聚合功能进行数据统计和分析,如术语...

    elasticsearch-7.17.3

    Elasticsearch 7.17.3 是一个高度可扩展的开源全文搜索引擎,以其强大的分布式、实时搜索和分析...了解如何优化索引和查询性能,如合理设置分片数量、使用合适的数据类型和分析器,也是提升Elasticsearch性能的关键。

    Elasticsearch Demo 读取word内容写入到Es上并展示在WebFrom页面上

    **Elasticsearch(ES)** 是一个开源的全文搜索引擎,基于Lucene构建,设计用于分布式、可扩展的数据存储和搜索。在这个"Elasticsearch Demo"项目中,我们将学习如何将Word文档的内容读取并写入Elasticsearch,以及...

    lucene相关jar+查询分析器jar

    7. **Lucene的扩展性**:除了基本功能,Lucene还提供了一些扩展模块,如Solr和Elasticsearch,它们提供了更高级的服务,如分布式搜索、实时索引、多租户支持等。 总结,"lucene相关jar+查询分析器jar"是一个包含了...

    Elasticsearch实战与原理解析 源代码.zip

    Elasticsearch是一个开源的全文搜索引擎,它以分布式、RESTful接口和实时性为特点,广泛应用于数据搜索、分析和监控。这份"**Elasticsearch实战与原理解析 源代码**"的压缩包文件提供了关于这个强大工具的实践案例和...

    Elasticsearch 开发手册

    Elasticsearch 是一个开源的、高扩展的、分布式的、提供多用户能力的全文搜索引擎,也是一个基于 Lucene 搜索的服务器,可以近乎实时地存储和搜索数据。Elasticsearch 能很方便地用于对大量数据进行搜索和分析,充分...

    PHP中 对es中的数据分页 查询

    总的来说,PHP与Elasticsearch的集成能帮助开发者高效地处理和查询大数据。通过封装查询类,不仅可以简化代码,还能提高代码的复用性和可维护性。在实际项目中,可以根据具体需求进行调整和扩展,构建更强大的ES查询...

    elasticsearch-7.2.1-win64.rar

    在搜索方面,Elasticsearch提供丰富的查询语法,包括全文搜索、短语匹配、范围查询、模糊查询等。7.2.1版本增强了分析器,使得对亚洲语言的支持更加完善,尤其是中文,能够更好地处理中文分词。此外,它还优化了搜索...

    ElasticSearch分布式搜索引擎 v7.17.18.zip

    Elasticsearch的查询语法基于JSON,称为Query DSL,支持丰富的查询类型,如全文搜索、范围查询、聚合查询等,使得查询操作更加灵活和精确。 **6. 聚合功能** Elasticsearch支持丰富的聚合操作,如术语聚合、度量...

    elasticsearch-7.14.2-windows-x86_64.zip

    Elasticsearch是一个开源的全文搜索引擎,它以分布式、RESTful接口和Apache Lucene库为基础,提供了高可扩展性、实时搜索、分析和存储数据的能力。这个"elasticsearch-7.14.2-windows-x86_64.zip"文件是Elastic...

    1_elasticsearch技术解析与实战

    2. **查询与过滤**:Elasticsearch支持丰富的查询语法,包括match查询、term查询、range查询、bool组合查询等,以及过滤器(Filter)用于无分数的精确匹配。 三、分布式特性 1. **自动发现**:节点间的自动发现是...

    Lucene全文检索入门项目 Java实现Maven项目 Elasticsearch 基础实战.zip

    通过编写Java代码,你会学习如何使用Lucene进行文本的分词、索引创建和查询执行。 接下来,项目会过渡到Elasticsearch,解释其分布式特性和如何与Java API交互。你会了解到如何安装和配置Elasticsearch,以及如何...

    lucene搜索引擎项目

    虽然Lucene本身是一个库,但有许多基于Lucene的框架和工具,如Solr和Elasticsearch,它们提供了更高级的功能,如分布式搜索、自动完成、多语言支持等。 7. **搜索引擎实例** "lucene搜索引擎项目"可能包含了从零...

Global site tag (gtag.js) - Google Analytics