大侠们看看我这个事务函数对不对

szg3827 2009-02-24 11:26:55

///<summary>
///执行多条SQL语句,实现数据库事务。
///</summary>
///<param name="SQLStringList">SQL语句的哈希表(key为sql语句,value是该语句的SqlParameter[])</param>
public bool ExecuteSqlTran(Hashtable SQLStringList)
{
bool tag = false;
// Database db = DatabaseFactory.CreateDatabase();
using (DbConnection dbconn = db.CreateConnection())
{
dbconn.Open();
DbTransaction dbtran = dbconn.BeginTransaction();
try
{
//执行语句
foreach (DictionaryEntry myDE in SQLStringList)
{
string strsql = myDE.Key.ToString();
SqlParameter[] cmdParms = (SqlParameter[])myDE.Value;
if (strsql.Trim().Length > 1)
{
DbCommand dbCommand = db.GetSqlStringCommand(strsql);
BuildDBParameter(db, dbCommand, cmdParms);
db.ExecuteNonQuery(dbCommand,dbtran);
}
}
dbtran.Commit();
tag = true;
}
catch
{
dbtran.Rollback();

}
finally
{
dbconn.Close();
}
return tag;
}
}

本地测试的时候,两张表都能插入成功的,放到网上正式用的时候,有时候能两张表都插入成功,有时候只有一张表插入成功,还有一张表没数据,不知道怎么回事啊。
有没有可能是因为用了hash表的原因啊。
...全文
50 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
szg3827 2009-02-26
  • 打赏
  • 举报
回复
顶一下,继续请教
jimu8130 2009-02-25
  • 打赏
  • 举报
回复
你可以加个日志来看看,实际添加是否成功。
另外using语句已经能够在最终执行connection.close,你的finally完全没必要加!

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧