1

是否可以确定 aNode是否在交易中?可以GraphDatabaseService通过方法得到一个Node.getGraphDatabase

我想做这样的事情:

public class Neo4JHelper {
    public void setProperty(Node node, String key, Object value) {
        if(isInTransaction(node) {
            node.setProperty(key, value);
        } else {
            throw new MyOwnException("You are trying to set a node outside a transaction... you suck");
        }
    }

    private boolean isInTransaction(Node node) {
        //Something
    }
}

我想这样做的原因是因为我想在尝试Neo4JHelper在事务之外使用我的类时给我的用户一个自定义错误。

另一种解决方案是,如果有可能以某种方式告诉编译器您需要一个事务来使用该方法/类,否则会给出编译错误。

4

2 回答 2

3

我对此有几种不同的看法,我不确定哪一种最有帮助。

第 1 点是您不需要进行此检查。如果您尝试创建任何虚拟节点,并且您不在事务中,则数据库将抛出异常,指示您不在事务中。因此,如果您想检测这种情况,只需尝试创建一个简单的测试节点即可。没有例外?你在交易中。

第 2 点可能是您在询问特定节点是否在事务中。我不知道有什么方法可以做到这一点,也许开发人员可以在上面添加一些东西。在事务中,可以在单个节点上获取读/写锁。因此,如果您有Transaction对象(您的方法没有),那么代理方法可能是确定给定节点上是否有锁。

第 3 点虽然我不能 100% 确定您在做什么,但您的代码表明解决此问题有不同的方法,因此您甚至不必回答这个问题。如果您希望您的用户得到一个自定义错误,请继续尝试修改该属性——如果 neo4j 抛出一个您不在事务中的异常,那么这就是您的答案。捕获该异常,然后抛出您的自定义错误。

于 2015-11-06T13:27:05.477 回答
2

节点不能在事务中,只有当前执行(线程)可以。

有一种内部方法可以检查正在运行的事务:

   ThreadToStatementContextBridge txManager = ((GraphDatabaseAPI) graphDB).getDependencyResolver().resolveDependency(ThreadToStatementContextBridge.class);
   txManager.hasTransaction();
于 2015-11-06T16:34:32.363 回答