我使用的是 .NET 2.0 和 SQL Server 2005。由于历史原因,应用程序代码使用 SQLTransaction,但一些存储过程也使用 T-SQL begin/commit/rollback tran 语句。这个想法是 DBTransaction 可以跨越许多存储过程,每个单独的 sproc 控制在其范围内发生的事情 - 实际上这些是嵌套事务。
代码的旧行为是,如果任何存储过程失败,应用程序逻辑也会导致外部 SQLTransaction 也回滚。但是现在我们想改变逻辑,这样,即使出现故障,外部事务也应该继续按顺序执行剩余的存储过程,最后,由于我们知道有故障,我们回滚整个 SQLTransaction。
问题在于,至少就目前的编码而言,如果任何存储过程执行 ROLLBACK,外部 SQLTransaction 似乎会丢失其连接,因此任何后续重用事务的尝试都会失败。有没有办法可以在 T-SQL 中回滚但仍保持外部 SQLTransaction?我在想也许保存点在这里可能会有所帮助,但我还不太了解它们。
使这种情况复杂化的是,并不总是有外部事务,所以我不能只删除 T-SQL 回滚,即。有时,sproc 会自行执行;有时在交易的背景下。
切换到 TransactionScope 会让事情变得更容易吗?
感谢您的任何建议......迈克