C# sqlclient数据库事务BeginTransaction()详解


重载

重载
BeginTransaction()

开始数据库事务。

BeginTransaction(IsolationLevel)

以指定的隔离级别启动数据库事务。

BeginTransaction(String)

以指定的事务名称启动数据库事务。

BeginTransaction(IsolationLevel, String)

以指定的隔离级别和事务名称启动数据库事务。

BeginTransaction()

开始数据库事务。

C#
public System.Data.SqlClient.SqlTransaction BeginTransaction ();

返回

SqlTransaction

表示新事务的对象。

例外

使用多个活动结果集 (MARS) 时,不允许并行事务。

不支持并行事务。

示例

下面的示例创建一个 SqlConnection 和一个 SqlTransaction 。 它还演示了如何使用 BeginTransaction 、、 Commit 和 Rollback 方法。

C#
private static void ExecuteSqlTransaction(string connectionString) { using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); SqlCommand command = connection.CreateCommand(); SqlTransaction transaction; // Start a local transaction. transaction = connection.BeginTransaction("SampleTransaction"); // Must assign both transaction object and connection // to Command object for a pending local transaction command.Connection = connection; command.Transaction = transaction; try { command.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (100, 'Description')"; command.ExecuteNonQuery(); command.CommandText = "Insert into Region (RegionID, RegionDescription) VALUES (101, 'Description')"; command.ExecuteNonQuery(); // Attempt to commit the transaction. transaction.Commit(); Console.WriteLine("Both records are written to database."); } catch (Exception ex) { Console.WriteLine("Commit Exception Type: {0}", ex.GetType()); Console.WriteLine(" Message: {0}", ex.Message); // Attempt to roll back the transaction. try { transaction.Rollback(); } catch (Exception ex2) { // This catch block will handle any errors that may have occurred // on the server that would cause the rollback to fail, such as // a closed connection. Console.WriteLine("Rollback Exception Type: {0}", ex2.GetType()); Console.WriteLine(" Message: {0}", ex2.Message); } } } } 

注解

此命令映射到 BEGIN TRANSACTION 的 SQL Server 实现。

必须使用或方法显式提交或回滚事务 Commit Rollback 。 为了确保 SQL Server 事务管理模型的 .NET Framework 数据提供程序正确执行,请避免使用其他事务管理模型,如 SQL Server 提供的模型。

 备注

如果未指定隔离级别,则使用默认的隔离级别。 若要使用方法指定隔离级别 BeginTransaction ,请使用 iso) (采用参数的重载 BeginTransaction 。 在事务完成后,为事务设置的隔离级别将保留,直到关闭或释放连接。 在未启用快照隔离级别的数据库中,将隔离级别设置为 snapshot 不会引发异常。 该事务将使用默认隔离级别完成。

 注意

如果事务已启动并且服务器上发生级别16或更高的错误,则在调用方法之前,不会回滚事务 Read 。 ExecuteReader上不引发异常。

 注意

如果查询返回大量的数据和调用 BeginTransaction , SqlException 则会引发,因为 SQL Server 在使用 MARS 时不允许并行事务。 若要避免此问题,请始终在打开任何读取器之前将事务与命令和/或连接关联。

 

引用:https://docs.microsoft.com/zh-cn/dotnet/api/system.data.sqlclient.sqlconnection.begintransaction?view=dotnet-plat-ext-5.0


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM