簡體   English   中英

是否可以使用Java API確定“節點”是否在Neo4J中的事務中?

[英]Is it possible to determine if a `Node` is in a transaction in Neo4J using the Java API?

是否可以確定Node是否在事務中? 這是可能得到一個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時,我想給用戶一個自定義錯誤。

另一個解決方案是,是否有可能以某種方式告訴編譯器您需要使用該方法/類的事務,否則會產生編譯錯誤。

我對此有幾種不同的看法,我不確定哪一種最有幫助。

第一點是您不需要執行此檢查。 如果您嘗試創建任何虛擬節點,並且您不在事務內部,那么數據庫將拋出異常,表明您不在事務中。 因此,如果您想檢測這種情況,只需嘗試創建一個簡單的測試節點即可。 沒有例外? 您正在交易中。

第二點可能是您在詢問某個特定節點是否在事務中。 我不知道有什么辦法,也許開發人員可以在上面添加一些東西。 在事務內,可以在單個節點上獲取讀/寫鎖定。 因此,如果您有Transaction對象(您的方法沒有),則替代方法可能是確定給定節點上是否有鎖。

第3點雖然我不是100%不確定您在做什么,但是您的代碼表明有解決此問題的另一種方法,因此您甚至不必回答這個問題。 如果您希望用戶遇到自定義錯誤,請繼續嘗試修改該屬性-如果neo4j拋出您不在事務中的異常,同樣,您也可以找到答案。 捕獲該異常,然后引發自定義錯誤。

節點不能處於事務中,只能是當前執行(線程)。

有一種內部方法可以檢查正在運行的事務:

   ThreadToStatementContextBridge txManager = ((GraphDatabaseAPI) graphDB).getDependencyResolver().resolveDependency(ThreadToStatementContextBridge.class);
   txManager.hasTransaction();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM