通常当你要更新多条关联SQL的时候,应该使用事务
举个例子:
银行转帐,从A划帐到B的帐户,
先运行一条SQL,扣除A帐户100元;
再运行一条SQL,增加B帐户100元
这2条SQL要么都执行成功,要么都不成功,
如果只有一条成功就会出现问题
这里就应该使用事务了,我写的一个例子:
参数是一个数组,保存了要执行的SQL
public bool ExecuteNone(string[] sql)
{
bool result;
OleDbConnection con = this.GetConn();
OleDbTransaction trans = con.BeginTransaction();//开始数据库事务
OleDbCommand dbComm = new OleDbCommand();
dbComm.Connection = con;
dbComm.Transaction = trans;
try
{
for (int i=0;i
if (sql[i] == null || sql[i] == "")
{//数组中有一个空项时跳过
continue;
}
dbComm.CommandText = sql[i];
dbComm.ExecuteNonQuery();
}
trans.Commit();//全部SQL执行成功后,提交数据库事务
result = true;
}
catch (System.Exception)
{
trans.Rollback();//如果出错,回滚数据库事务
result = false;
}
this.CloseConn(con);
return result;
}//end ExecuteNone
完成一个任务需要多条Sql语句的情况下使用事务