我有一个mysql数据库作为主数据的基本数据存储.对于类似于“朋友之友”的复杂多级查询,请输入“我有一个图形数据存储neo4j”.我面临的问题是在维护事务时,我必须在mysql中插入用户记录,并在neo4j中插入用户节点.现在我希望他们两个都能成功.我所完成的是如果neo4j插入成功,那么我将插入mysql用户记录.但是如果插入mysql用户记录失败怎么办,我的状态不一致.如果我先插入mysql,然后再插入neo4j,也会发生类似情况.有什么办法可以完成mysql和neo4j的事务.我是否需要维护某种失败的事务日志并在以后执行?
谢谢!我知道许多人不同意neo4j和mysql的组合方法,但是如果我可以使用一致的数据存储,那我现在是最好的解决方案.
解决方法:
多语言持久性(多数据库系统)正变得司空见惯,这是一个普遍的挑战.您将找不到跨不同数据库进行交易的任何内置机制.现在:尽管您的方案没有一个单一的“正确答案”,(但我会尽力保持我的答案目标),但请考虑一下您的记录系统-哪个数据库掌握了真相,需要正确吗?我的猜测是,它是MySQL数据库.
因此:现在,您已经妥善处理了MySQL数据库,以事务方式保存内容.现在有您的Neo4j数据库,该数据库用于辅助功能(在您的情况下,寻找朋友).为什么不在事实之后添加Neo4j图形节点(和关系)作为单独的操作?如果延迟插入Neo4j,会真的影响系统的运行吗?对您的图形数据库进行最终一致的更新是否有害?我怀疑,即使进行后续操作,延迟也将是最小的.就是说:只有您知道您的应用程序,以及数据库之间的同步是否需要绝对的.