Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/solr/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 从Solr 5.0获取所有可能的数据_Java_Solr_Solrj - Fatal编程技术网

Java 从Solr 5.0获取所有可能的数据

Java 从Solr 5.0获取所有可能的数据,java,solr,solrj,Java,Solr,Solrj,我正在使用Solr4.4作为数据存储的项目中工作,我想升级到Solr5.0 问题是,当我使用solrj发送查询以获取所有可能的结果时,查询如下所示: SolrQuery query = new SolrQuery(); query.setQuery("*:*"); query.addSort("sorting_score", ORDER.desc); query.addFilterQuery("label_list:\"" + currLabel + "\""); query.set("rows

我正在使用Solr4.4作为数据存储的项目中工作,我想升级到Solr5.0

问题是,当我使用solrj发送查询以获取所有可能的结果时,查询如下所示:

SolrQuery query = new SolrQuery();
query.setQuery("*:*");
query.addSort("sorting_score", ORDER.desc);
query.addFilterQuery("label_list:\"" + currLabel + "\"");
query.set("rows", Integer.MAX_VALUE);
(我知道这可能是错误的,因为它可以获取太多数据,但这是我的情况)

这段代码在Solr4.4中运行良好,但当我迁移到5时,它会导致
NegativeArraySizeException
exception,这就是错误所在

org.apache.solr.client.solrj.impl.HttpSolrClient$RemoteSolrException: Error from server at http://localhost:8983/solr/Event: java.lang.NegativeArraySizeException
    at org.apache.lucene.util.PriorityQueue.<init>(PriorityQueue.java:56)
    at org.apache.lucene.util.PriorityQueue.<init>(PriorityQueue.java:37)
    at org.apache.solr.handler.component.ShardFieldSortedHitQueue.<init>(ShardDoc.java:113)
    at org.apache.solr.handler.component.QueryComponent.mergeIds(QueryComponent.java:955)
    at org.apache.solr.handler.component.QueryComponent.handleRegularResponses(QueryComponent.java:743)
    at org.apache.solr.handler.component.QueryComponent.handleResponses(QueryComponent.java:722)
    at org.apache.solr.handler.component.SearchHandler.handleRequestBody(SearchHandler.java:350)
    at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:144)
    at org.apache.solr.core.SolrCore.execute(SolrCore.java:2006)
    at org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:777)
    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:413)
    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:204)
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557)
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384)
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
    at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255)
    at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
    at org.eclipse.jetty.server.Server.handle(Server.java:368)
    at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:489)
    at org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53)
    at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942)
    at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004)
    at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:640)
    at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235)
    at org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72)
    at org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
    at java.lang.Thread.run(Thread.java:745)
org.apache.solr.client.solrj.impl.HttpSolrClient$RemoteSolrException:位于的服务器出错http://localhost:8983/solr/Event: java.lang.NegativeArraySizeException
位于org.apache.lucene.util.PriorityQueue(PriorityQueue.java:56)
位于org.apache.lucene.util.PriorityQueue(PriorityQueue.java:37)
位于org.apache.solr.handler.component.ShardFieldSortedHitQueue(ShardDoc.java:113)
位于org.apache.solr.handler.component.QueryComponent.mergeIds(QueryComponent.java:955)
位于org.apache.solr.handler.component.QueryComponent.handleRegularResponses(QueryComponent.java:743)
位于org.apache.solr.handler.component.QueryComponent.handleResponses(QueryComponent.java:722)
位于org.apache.solr.handler.component.SearchHandler.HandlerRequestBody(SearchHandler.java:350)
位于org.apache.solr.handler.RequestHandlerBase.HandlerRequest(RequestHandlerBase.java:144)
位于org.apache.solr.core.SolrCore.execute(SolrCore.java:2006)
位于org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:777)
位于org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:413)
位于org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:204)
位于org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419)
位于org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455)
位于org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)
位于org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557)
位于org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)
位于org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075)
位于org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384)
位于org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)
位于org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009)
位于org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
位于org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255)
位于org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)
位于org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
位于org.eclipse.jetty.server.server.handle(server.java:368)
位于org.eclipse.jetty.server.AbstractHttpConnection.HandlerRequest(AbstractHttpConnection.java:489)
位于org.eclipse.jetty.server.blockingttpconnection.handleRequest(blockingttpconnection.java:53)
位于org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942)
位于org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004)
http.HttpParser.parseNext(HttpParser.java:640)
http.HttpParser.parseAvailable(HttpParser.java:235)
位于org.eclipse.jetty.server.blockingttpconnection.handle(blockingttpconnection.java:72)
位于org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)
位于org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
位于org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
运行(Thread.java:745)

知道为什么会发生这种情况吗?

如果您对所有这些数据感兴趣,您应该使用此处描述的深度分页迭代:

从堆栈跟踪中,有一个对过滤器的引用,我们可以在代码片段中看到过滤器查询参数。请尝试删除它并执行查询。在使用java之前,您可以先尝试使用curl和see进行查询。希望对你有帮助,我知道已经很晚了。此问题是由于query.set(“rows”,Integer.MAX_VALUE)

我怀疑这与
query.set(“行”,Integer.MAX_值)有关使用分页机制,而不是尝试获取尽可能多的行。