[英]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.