C#中什么时候使用数据库事务事件

来源:百度知道 编辑:UC知道 时间:2024/05/30 05:51:59
我想问问各位高手,什么时候,什么情况下我该使用数据库事务呢?
SqlTransaction myt = conn.BeginTransaction();

就是什么时候使用begin transcation开始事务
commit transcation 提交事务
rollback transcation 回滚事务
save transcation 保存事务

先谢谢大家了!请帮帮我!谢谢!

通常当你要更新多条关联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<sql.Length;i++)
{//执行数组中的SQL
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);

r