gpt4 book ai didi

c# - 如何在 .net c# 中的数据库对象中应用事务回滚

转载 作者:搜寻专家 更新时间:2023-10-30 20:06:16 24 4
gpt4 key购买 nike

有谁知道如何在 .net c# 中的数据库对象中应用事务回滚?

例子:我原来有以下代码:

   protected void btnSave_Click(object sender, EventArgs e)
{
try {
m_test = CreateTest();
} catch{}
}


private Db.Test CreateTest()
{
var test= new Test();
test.Title = sTitle.SelectedValue;
test.FirstName = sFirstName.Text;
test.LastName = sLastName.Text;
test.PhoneHome = sHomePhone.Text;
test.PhoneWork = sWorkPhone.Text;
test.PhoneMobile = sMobile.Text;
test.EmailAddress = sEmail.Text;
test.Save();

return test;
}

然后我尝试将事务回滚操作应用到代码中并在其中应用以下代码...然后我在方法 CreateTest 下进行堆栈。我不知道如何应用数据库对象的代码

       protected void btnSave_Click(object sender, EventArgs e)
{

SqlConnection connDB = new SqlConnection();
SqlCommand cmdExecuting = new SqlCommand();

try {
connDB = new SqlConnection(connection_string);
cmdExecuting.Connection = connDB;
connDB.Open();
cmdExecuting.Transaction = connDB.BeginTransaction();

m_test = CreateTest(cmdExecuting);

if (m_test != 0) {
cmdExecuting.Transaction.Rollback();
return;
}
} catch{}
}


private Db.Test CreateTest(SqlCommand cmdExecuting)
{
var test= new Test();
test.Title = sTitle.SelectedValue;
test.FirstName = sFirstName.Text;
test.LastName = sLastName.Text;
test.PhoneHome = sHomePhone.Text;
test.PhoneWork = sWorkPhone.Text;
test.PhoneMobile = sMobile.Text;
test.EmailAddress = sEmail.Text;
test.Save();

return test;
}

有谁知道在这种情况下如何在 CreateTest() 中编写代码?

最佳答案

看看 TransactionScope类,它提供了几个好处,包括

  • 自动交易登记在范围内建立联系
  • 自动回滚事务发生异常时
  • 在我看来它也使代码更清晰一点,因为它减少了所需的代码量

.

try    
{
using (TransactionScope scope = new TransactionScope())
{
m_test = CreateTest();
scope.Complete(); // Commit transaction
}
}
catch (Exception ex)
{
// Transaction is automatically rolled back
}

另请参阅文章 Introducing System.Transactions in the .NET Framework 2.0一个很好的起点。

关于c# - 如何在 .net c# 中的数据库对象中应用事务回滚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6067651/

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