asp.net怎么使用事务啊!求救啊
现在的问题是用户信息插入了,而且插入了2条,公司信息没有插入进去,看了半天也没有看出来,是什么问题呢。...
现在的问题是用户信息插入了,而且插入了2条 ,公司信息没有插入进去,看了半天也没有看出来,是什么问题呢。
展开
展开全部
把tran=Conn.BeginTransaction()和下面的cmd.Transaction=tran;写到try块的外面...
这个涉及到变量作用域,你在try外面并没有实例化tran,因此catch到错误时,rollback的只是一个空引用....
给你写个例子
SqlTransaction tran=Conn.BeginTransaction();
cmd.Transaction=tran;
//这里赋值SQL语句和参数,方便抛出类型不匹配的错误
//....
try
{
cmd.ExecuteNonQuery();
tran.Commit();
}
catch
{
tran.Rollback();
}
这个涉及到变量作用域,你在try外面并没有实例化tran,因此catch到错误时,rollback的只是一个空引用....
给你写个例子
SqlTransaction tran=Conn.BeginTransaction();
cmd.Transaction=tran;
//这里赋值SQL语句和参数,方便抛出类型不匹配的错误
//....
try
{
cmd.ExecuteNonQuery();
tran.Commit();
}
catch
{
tran.Rollback();
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
Storm代理
2023-08-29 广告
2023-08-29 广告
"StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,I...
点击进入详情页
本回答由Storm代理提供
展开全部
你这程序肯定不会回滚了,一个是cmd.sqltransaction=tran,然后又一个cmdt,应该这样:
cmd.sqltransaction=tran;
cmd.sqlconnection=conn;
cmd.commandtext=sql1;
cmd.executenonquery();
cmd.commandtext=sql2;
cmd.executenonquery();
tran.commit();
cmd.sqltransaction=tran;
cmd.sqlconnection=conn;
cmd.commandtext=sql1;
cmd.executenonquery();
cmd.commandtext=sql2;
cmd.executenonquery();
tran.commit();
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
好像程序没有错?你存储过程写错了,只能这样
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询