使用Cypher在嵌入式Neo4J应用程序中创建节点

时间:2016-03-26 16:04:51

标签: java neo4j graph-databases

我将我的系统与 neo4j 集成在一起,使用 Cypher 查询语言创建节点对我来说很有趣,因此,作为测试,I& #39;我试图做这样的事情:

String path = "test.graphdb";

AbstractDatabase db = new Neo4jDatabase(path, true, false);

db.makeQuery("CREATE (n:Dog {name:'Sofia'})");
db.makeQuery("CREATE (n:Dog {name:'Laika'})");     db.makeQuery("CREATE (n:Dog {name:'Gaia'})");

Result result = db.makeQuery("MATCH (n:Dog) RETURN n");

boolean hasNext = result.hasNext();

System.out.println(hasNext);

在Neo4jDatabase类中,我有这个makeQuery方法,如下所示:

public Result makeQuery(String string)
{
    try(Transaction ignored = this.db.beginTx();
        Result result = this.db.execute(string) )
    {
        return result;
    }

}

不幸的是,它返回false,好像没有创建节点!有什么问题?

1 个答案:

答案 0 :(得分:3)

你自己说,你忽略了交易:)

在成功迭代结果后,您应该在事务块中调用tx.success()

当您已经关闭交易时,不要分发结果,其中的数据将无法在tx之外访问。

对于这些简单的语句,您也可以将tx-handling留给cypher,无需启动手动事务。

但是你必须迭代或result.close()你的结果才能完成Cypher操作。