繁体   English   中英

Lucene查询不起作用

[英]Lucene Query not working

我正在使用Apache Lucene 5.0.0,并在使用QueryParser时遇到问题。 我试图创建一个查询,但得到了ParseException。

以下是我的代码:

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.queryparser.classic.ParseException;
import org.apache.lucene.queryparser.classic.QueryParser;

public class QueryTest {
    public static void main(String[] args) {
        QueryParser parser = new QueryParser("field", new StandardAnalyzer());
        try {
            parser.Query("query");
        } catch (ParseException e) {
            e.printStackTrace();
        }
    }
}

这是我得到的例外:

org.apache.lucene.queryparser.classic.ParseException: Encountered "<EOF>" at line 1, column 0.
Was expecting one of:
    <NOT> ...
    "+" ...
    "-" ...
    <BAREOPER> ...
    "(" ...
    "*" ...
    <QUOTED> ...
    <TERM> ...
    <PREFIXTERM> ...
    <WILDTERM> ...
    <REGEXPTERM> ...
    "[" ...
    "{" ...
    <NUMBER> ...
    <TERM> ...
    "*" ...

    at org.apache.lucene.queryparser.classic.QueryParser.generateParseException(QueryParser.java:698)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_consume_token(QueryParser.java:580)
    at org.apache.lucene.queryparser.classic.QueryParser.Clause(QueryParser.java:265)
    at org.apache.lucene.queryparser.classic.QueryParser.Query(QueryParser.java:171)
    at QueryTest.main(QueryTest.java:9)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)

如果有帮助,我提供了以下jar文件:

  • Lucene的 - 分析 - 共5.0.0.jar
  • Lucene的核心 - 5.0.0.jar
  • Lucene的查询-5.0.0.jar
  • 的Lucene的QueryParser-5.0.0.jar
  • Lucene的沙箱-5.0.0.jar

我不知道为什么会抛出该异常以及如何解决它。 网上的例子很相似,但似乎效果不错。

谢谢。

我认为您使用的是错误的方法,您尝试做的是:

    QueryParser parser = new QueryParser("field", new StandardAnalyzer());
    try {
        Query query = parser.parse("query"); // changed this line
    } catch (ParseException e) {
        e.printStackTrace();
    }

根据文档:

查询字符串的语法如下:查询是一系列子句。 子句的前缀可以是:

  • 加号( + )或减号( - ),分别表示该子句是必需的或禁止的; 要么
  • 一个带冒号的术语,表示要搜索的字段。 这使人们能够构建搜索多个字段的查询。

子句可以是:

  • 一个术语,指示包含该术语的所有文档; 要么
  • 嵌套在括号中的嵌套查询。 请注意,这可能与使用+ / -前缀要求任何一组术语的。

因此,在BNF中,查询语法为:

Query  ::= ( Clause )*
   Clause ::= ["+", "-"] [<TERM> ":"] ( <TERM> | "(" Query ")" )

有关更多信息,请在此处查看-http://lucene.apache.org/core/5_0_0/queryparser/org/apache/lucene/queryparser/classic/QueryParser.html

特别是要解决您的问题,可能值得将“ field:Query”字符串解析为查询

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM