gpt4 book ai didi

java - Neo4j java api : Transactions, 多处理和线程安全

转载 作者:太空宇宙 更新时间:2023-11-04 07:34:58 27 4
gpt4 key购买 nike

在尝试 Neo4j 图时,我发现在任何给定时间只能有一个具有“给定交易名称”的交易。这是真的还是我在理解交易时犯了一些错误?

例如考虑以下代码:

updateNode(Node node){
Transaction txNode = graphDB.beginTx();
try{
//do some operations on node
txNode.success();
}finally{
txNode.finish();
}
}

如果我有多个进程或多线程在同一个“graphDB”上运行,其中每个进程/线程可以为不同的节点调用上述函数,是否会像只有一个名为“txNode”的事务一样,这会导致线程/进程之间出现问题?

我认为这是因为,事务是在图级别创建的,因此每个事务(需要并行使用)必须具有不同的名称。

如果我错了,请澄清...

如果我是对的,我们该如何解决这种情况?我们如何为每个并行运行的线程/进程创建具有不同名称的事务?

最佳答案

事务“txNode”只是创建的事务实例的变量名称。每次执行您的方法时,都会创建一个新事务。同一个不会被重复使用。您不必担心在应用程序级别区分事务。

关于java - Neo4j java api : Transactions, 多处理和线程安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17037184/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com