首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >我应该提交还是回滚读事务?

我应该提交还是回滚读事务?
EN

Stack Overflow用户
提问于 2008-11-21 19:10:27
回答 12查看 34.6K关注 0票数 102

我有一个在事务中执行的读查询,这样我就可以指定隔离级别。查询完成后,我应该做什么?

  • 提交事务
  • 回滚事务
  • 不做任何事情(这将导致事务在using块结束时回滚)

每种方法的含义是什么?

代码语言:javascript
复制
using (IDbConnection connection = ConnectionFactory.CreateConnection())
{
    using (IDbTransaction transaction = connection.BeginTransaction(IsolationLevel.ReadUncommitted))
    {
        using (IDbCommand command = connection.CreateCommand())
        {
            command.Transaction = transaction;
            command.CommandText = "SELECT * FROM SomeTable";
            using (IDataReader reader = command.ExecuteReader())
            {
                // Read the results
            }
        }

        // To commit, or not to commit?
    }
}

编辑:问题不在于是否应该使用事务,或者是否有其他方法来设置事务级别。问题是,提交或回滚不修改任何内容的事务是否有区别。有性能上的差异吗?它会影响其他连接吗?还有其他区别吗?

EN

回答 12

Stack Overflow用户

回答已采纳

发布于 2008-11-21 21:47:08

你要承诺。句号。没有其他明智的选择。如果你启动了一个事务,你应该关闭它。提交将释放您可能拥有的任何锁,并且使用ReadUncommitted或Serializable隔离级别也同样合理。依赖隐式回滚-虽然在技术上可能是等价的-只是形式很差。

如果这还不能说服您,想象一下下一个人在您的代码中间插入update语句,并且必须跟踪发生的隐式回滚并删除他的数据。

票数 54
EN

Stack Overflow用户

发布于 2008-11-21 19:22:32

如果您没有更改任何内容,那么您可以使用提交或回滚。任何一个都会释放你已经获得的任何读锁,因为你没有做任何其他的修改,所以它们是等价的。

票数 33
EN

Stack Overflow用户

发布于 2008-11-21 19:17:19

如果您开始一个事务,那么最佳实践总是提交它。如果use(事务)块中抛出异常,事务将自动回滚。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/309834

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档