1

对于三种 SQL 类型(MySql、SQLite 和 PostgreSQL),我希望/需要以相同的方式处理保存点。

现在我的应用程序可以在一个大事务中更改数据库中的不同条目,并且需要一些嵌套事务来实现程序的特殊行为。

所以问题是,如果我创建类似的东西:

BEGIN TRANSACTION;
--random insert/update statements
SET SAVEPOINT sp1;
--more random inserts/updates
SET SAVEPOINT sp2;
--inserts n stuff

(是的,语法可能不正确,这只是一个例子)

所以我想知道是否可以在两个保存点之间进行回滚sp1并且sp2之后不回滚插入/更新sp2

4

1 回答 1

5

保存点不会做你想做的事。当您回滚到某个保存点时,该保存点之后的所有内容都会回滚,无论是否创建了后来的保存点。

将保存点想象为“堆栈”。你不能从堆栈中间拉出一些东西,你必须把所有东西都移到你想要的层。

您可能正在寻找自主交易。您要使用的数据库都不支持它们。在 PostgreSQL 中,您可以使用 dblink 模块与数据库建立新连接并使用它来解决此问题;请参阅http://www.postgresql.org/docs/current/static/dblink.html。我不知道 MySQL 或 SQLite 提供了哪些解决方案,但既然您知道您正在寻找的术语,Google 会提供帮助。

如果可能,我建议您找到解决此应用程序设计要求的方法。让您的应用程序使用两个数据库连接和两个事务来执行您需要的操作,并根据需要协调两者。

于 2013-02-06T22:55:48.073 回答