gpt4 book ai didi

c# - SqlTransaction.Commit() 之前的 SqlCommand.Dispose()?

转载 作者:可可西里 更新时间:2023-11-01 08:08:27 25 4
gpt4 key购买 nike

在提交事务之前处理分配给事务的命令是否有效?我自己测试了以下代码,它似乎工作正常,但这是一个相当小的例子,所以如果有人肯定知道,我正在寻找确认。

internal static void TestTransaction()
{
try
{
Program.dbConnection.Open();
using (SqlTransaction transaction = Program.dbConnection.BeginTransaction())
{
Boolean doRollback = false;
for (int i = 0; i < 10; i++)
{
using (SqlCommand cmd = new SqlCommand("INSERT INTO [testdb].[dbo].[transactiontest] (testvalcol) VALUES (@index)", Program.dbConnection, transaction))
{
cmd.Parameters.AddWithValue("@index", i);
try
{
cmd.ExecuteNonQuery();
}
catch (SqlException)
{
doRollback = true;
break;
}
}
}
if (doRollback)
transaction.Rollback();
else
transaction.Commit();
}
}
finally
{
Program.dbConnection.Close();
}
}

最佳答案

连接、事务和命令对象只是将命令发送到数据库的工具。一旦执行命令,数据库就会收到它。无论您之后如何处理命令对象,处理它、燃烧它或将它射向月球,这个事实都不会改变。 (只能回滚)。

您可以在一个 SqlConnection 范围内创建和处理任意数量的命令(带或不带 SqlTransaction)。您可以在一个 SqlConnection 中启动和处理任意数量的事务。要证明这一点,请参阅:

using (var conn = new SqlConnection(@"server=(local)\sql2008;database=Junk;Integrated Security=SSPI"))
{
conn.Open();
// Repeat this block as often as you like...
using (var tran = conn.BeginTransaction())
{
using (var cmd = new SqlCommand("INSERT INTO Mess VALUES ('mess1')", conn, tran))
{
cmd.ExecuteNonQuery(); // Shows in Sql profiler
}
tran.Commit(); // Commits
}
using (var cmd = new SqlCommand("INSERT INTO Mess VALUES ('mess2')", conn))
{
cmd.ExecuteNonQuery(); // Executes and commits (implicit transaction).
}
}

当然,对于健康的代码,您需要以正确的顺序处理所有对象。在处理 SqlConnection 之后处理命令可能会导致连接对象保留在内存中。

关于c# - SqlTransaction.Commit() 之前的 SqlCommand.Dispose()?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9297650/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com