1

我目前正在使用 neo4j 1.8.1 。当我查询 neo4j 索引以获取一些节点时,我得到 NotInTransactionException 。

以下是一个简单的查询,我在 neo4j 上执行

 if (graphDb.index().existsForNodes("NODEINDEX")) {
  IndexHits<Node> hits = graphDb.index().forNodes(NODEINDEX).query(query);
}

以下是异常的堆栈跟踪。

"message" : "Error fetching transaction for current thread",
"exception" : "NotInTransactionException",
"stacktrace" : [ "org.neo4j.kernel.impl.index.IndexConnectionBroker.getCurrentTransaction(IndexConnectionBroker.java:134)", "org.neo4j.kernel.impl.index.IndexConnectionBroker.acquireReadOnlyResourceConnection(IndexConnectionBroker.java:84)", "org.neo4j.index.impl.lucene.LuceneIndex.getReadOnlyConnection(LuceneIndex.java:105)", "org.neo4j.index.impl.lucene.LuceneIndex.query(LuceneIndex.java:245)", "org.neo4j.index.impl.lucene.LuceneIndex.query(LuceneIndex.java:227)", "org.neo4j.index.impl.lucene.LuceneIndex.query(LuceneIndex.java:238)", "com.uprr.netcontrol.starmap.neo4j.plugins.aggregate_node_status.NodeStatusHelper.getGraphNodes(NodeStatusHelper.java:39)", 

我在 Neo4j api 中找到了以下内容。

 private Transaction getCurrentTransaction() throws NotInTransactionException
{
    try
    {
        return transactionManager.getTransaction();
    }
    catch ( SystemException se )
    {
        throw new NotInTransactionException(
                "Error fetching transaction for current thread", se );
    }
}

我们是否需要显式地启动一个事务来查询 neo4j 索引?
有什么想法吗?
谢谢

4

2 回答 2

1

这是一个理论:我不知道这是否只是粘贴在这里的代码的问题,但检查:

if (graphDb.index().existsForNodes("NODEINDEX"))

检查名为“NODEINDEX”的索引,但实际查询

graphDb.index().forNodes(NODEINDEX).query(query);

检查在常量 NODEINDEX 中命名的索引。这两个可能不一样,因此它会尝试为您创建该索引,但由于不在事务中而失败。

于 2013-03-22T07:58:40.443 回答
0

如果没有现有的适当索引,我认为它会在返回之前创建一个;此操作需要包装在事务中。

于 2013-10-29T22:17:44.390 回答