gpt4 book ai didi

c# - 带有 SqlTransaction 的 ExecuteScalar()

转载 作者:行者123 更新时间:2023-11-30 14:54:47 25 4
gpt4 key购买 nike

我正在尝试使用 sqltransaction 和 executescalar 对数据库执行两次插入,以返回第一次插入的输出 ID。

这是代码:

try
{
using (SqlConnection conn = new SqlConnection("ConnectionString"))
{
conn.Open();

SqlTransaction safetransaction = conn.BeginTransaction();

foreach (var dado in NFSe)
{

SqlCommand cmd_NFSe = new SqlCommand("SqlCommand", conn, safetransaction);


var newID = cmd_NFSe.ExecuteScalar();

foreach (var serv in Servico)
{

string ID = newID.Tostring();

SqlCommand cmd_NFSeServ = new SqlCommand("SqlCommand", conn, safetransaction);


cmd_NFSeServ.ExecuteNonQuery();
}

}
}
}

catch (SqlException ex)
{
MessageBox.Show(ex.ToString());
}

但这行不通。没有任何内容被插入到数据库中,我也没有收到任何错误或异常,只是什么也没有发生。

如果我使用相同的代码但没有 sqltransaction,一切都很好。

有什么想法吗?

最佳答案

您需要调用 safetransaction.Commit();

关于c# - 带有 SqlTransaction 的 ExecuteScalar(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26915171/

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