查询短语在单个字段上:
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技术精华网
相关推荐
使用Elasticsearch查询in和not in的实现方式可以满足我们各种查询需求,提高我们的开发效率和查询速度。 本文总结了使用Elasticsearch查询in和not in的实现方式,希望对大家的学习或者工作具有一定的参考价值。
《深入理解Lucene 4.4与Elasticsearch:源码剖析与实战探索》 Lucene和Elasticsearch是两个在信息检索和大数据分析领域中不可或缺的重要工具。Lucene作为一个高性能、全文本搜索库,提供了丰富的索引和搜索功能;而...
另外,它兼容lucene语法,可以与即有的基于lucene与elasticsearch的应用无缝整合,即如果采用lucene语法描述客户关注的信息,那么即可以使用Tripod解决实时推送问题,也可以实现从lucene或elasticsear
**Lucene索引和查询** Lucene是Apache软件基金会的开放源码全文搜索引擎库,它提供了文本检索的核心工具,使得开发者能够快速构建自己的搜索应用。本项目中的代码旨在展示如何利用Lucene对多个文件夹下的数据进行...
ElasticSearch客户端工具是用于管理和操作Elasticsearch(ES)集群的重要软件,它们提供了一种直观、高效的方式来查看和管理ES集群的状态、索引、文档以及执行查询和分析任务。这些工具极大地简化了对Elasticsearch...
Elasticsearch(ES)是一种流行的开源全文搜索引擎,它基于Lucene库构建,被广泛用于大数据分析、日志聚合、实时搜索和索引等场景。官方提供的测试数据集是检验Elasticsearch功能、性能和稳定性的关键资源,可以帮助...
3. **查询与过滤**:掌握 Elasticsearch 的查询语法,包括匹配查询、范围查询、模糊查询等,以及如何使用过滤器来筛选结果。 4. **聚合分析**:学习如何使用 Elasticsearch 的聚合功能进行数据统计和分析,如术语...
Elasticsearch 7.17.3 是一个高度可扩展的开源全文搜索引擎,以其强大的分布式、实时搜索和分析...了解如何优化索引和查询性能,如合理设置分片数量、使用合适的数据类型和分析器,也是提升Elasticsearch性能的关键。
**Elasticsearch(ES)** 是一个开源的全文搜索引擎,基于Lucene构建,设计用于分布式、可扩展的数据存储和搜索。在这个"Elasticsearch Demo"项目中,我们将学习如何将Word文档的内容读取并写入Elasticsearch,以及...
7. **Lucene的扩展性**:除了基本功能,Lucene还提供了一些扩展模块,如Solr和Elasticsearch,它们提供了更高级的服务,如分布式搜索、实时索引、多租户支持等。 总结,"lucene相关jar+查询分析器jar"是一个包含了...
Elasticsearch是一个开源的全文搜索引擎,它以分布式、RESTful接口和实时性为特点,广泛应用于数据搜索、分析和监控。这份"**Elasticsearch实战与原理解析 源代码**"的压缩包文件提供了关于这个强大工具的实践案例和...
Elasticsearch 是一个开源的、高扩展的、分布式的、提供多用户能力的全文搜索引擎,也是一个基于 Lucene 搜索的服务器,可以近乎实时地存储和搜索数据。Elasticsearch 能很方便地用于对大量数据进行搜索和分析,充分...
总的来说,PHP与Elasticsearch的集成能帮助开发者高效地处理和查询大数据。通过封装查询类,不仅可以简化代码,还能提高代码的复用性和可维护性。在实际项目中,可以根据具体需求进行调整和扩展,构建更强大的ES查询...
在搜索方面,Elasticsearch提供丰富的查询语法,包括全文搜索、短语匹配、范围查询、模糊查询等。7.2.1版本增强了分析器,使得对亚洲语言的支持更加完善,尤其是中文,能够更好地处理中文分词。此外,它还优化了搜索...
Elasticsearch的查询语法基于JSON,称为Query DSL,支持丰富的查询类型,如全文搜索、范围查询、聚合查询等,使得查询操作更加灵活和精确。 **6. 聚合功能** Elasticsearch支持丰富的聚合操作,如术语聚合、度量...
Elasticsearch是一个开源的全文搜索引擎,它以分布式、RESTful接口和Apache Lucene库为基础,提供了高可扩展性、实时搜索、分析和存储数据的能力。这个"elasticsearch-7.14.2-windows-x86_64.zip"文件是Elastic...
2. **查询与过滤**:Elasticsearch支持丰富的查询语法,包括match查询、term查询、range查询、bool组合查询等,以及过滤器(Filter)用于无分数的精确匹配。 三、分布式特性 1. **自动发现**:节点间的自动发现是...
通过编写Java代码,你会学习如何使用Lucene进行文本的分词、索引创建和查询执行。 接下来,项目会过渡到Elasticsearch,解释其分布式特性和如何与Java API交互。你会了解到如何安装和配置Elasticsearch,以及如何...
虽然Lucene本身是一个库,但有许多基于Lucene的框架和工具,如Solr和Elasticsearch,它们提供了更高级的功能,如分布式搜索、自动完成、多语言支持等。 7. **搜索引擎实例** "lucene搜索引擎项目"可能包含了从零...