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

我想问问各位高手,什么时候,什么情况下我该使用数据库事务呢?SqlTransactionmyt=conn.BeginTransaction();就是什么时候使用begin... 我想问问各位高手,什么时候,什么情况下我该使用数据库事务呢?
SqlTransaction myt = conn.BeginTransaction();

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

先谢谢大家了!请帮帮我!谢谢!
展开
 我来答
ThinkIBM
2007-09-13 · TA获得超过5289个赞
知道大有可为答主
回答量:3263
采纳率:0%
帮助的人:5487万
展开全部
通常当你要更新多条关联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);

return result;
}//end ExecuteNone
287641467
2007-09-27 · TA获得超过765个赞
知道小有建树答主
回答量:850
采纳率:0%
帮助的人:698万
展开全部
完成一个任务需要多条Sql语句的情况下使用事务
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式