处理事务的两种方式

转载 2011年01月15日 21:50:00

转自http://www.cnblogs.com/hnsdwhl/archive/2011/01/15/1936428.html

当要对两张表同时进行操作时,我们通常都要使用事务,避免在操作的过程中产生异常,而导致结果的不正确,我们可以在数据库中定义事务的处理,也可以利用asp.net的事务处理类来操作事务。具体这两张方法的使用,请看下面的介绍:

1.在数据库中进行处理,主要使用begin transaction,commit transaction,rollback transaction三个操作来实现,另外通过借助@@ERROR函数获取sql语句执行过程中是否发生了错误。

declare @error int
begin transaction
update AccountOfBank
set balance=balance+5000 where accountName='张三'
set @error=@error+@@ERROR
update AccountOfBank
set balance=balance-5000 where accountName='李四'
set @error=@error+@@ERROR
if(@error<>0)
rollback transaction
else
commit transaction

2.使用asp.net的事务处理类来操作

  

SqlConnection con = new SqlConnection("server=.;database=Test;uid=sa;pwd=123456");
con.Open();
SqlTransaction tran
= con.BeginTransaction();
SqlCommand cmd
= new SqlCommand();
cmd.Connection
= con;
cmd.Transaction
= tran;
try
{
cmd.CommandText
= "update AccountOfBank set balance=balance-5000 where accountName='张三'";
cmd.ExecuteNonQuery();
cmd.CommandText
= "update AccountOfBank set balance=balance+5000 where accountName='李四'";
cmd.ExecuteNonQuery();
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
}
finally
{
con.Close();
}

myBatis事务处理

1. myBatis单独使用时,使用SqlSession来处理事务:  Java代码   public class MyBatisTxTest {          p...
  • qqlrq
  • qqlrq
  • 2015年05月18日 17:52
  • 2973

Spring中的几种事务处理方式

1、用原始的transactionfactorybean的,代理dao事务处理 2、用aop:config声明要进行事务增强的切面,用tx:advice声明具体方法的事务属性,及应用...
  • wangheid
  • wangheid
  • 2010年08月31日 14:16
  • 3124

多线程实现的两种方式及其区别

继承Threadpublic class Demo2_Thread { public static void main(String[] args) { MyThread mt ...
  • StriverLi
  • StriverLi
  • 2017年02月26日 21:07
  • 1626

Spring中依赖注入的两种方式的区别

1:Spring中依赖注入的两种方式:  (1):通过 setter 方法注入:                 其中,name属性的取值依setter方法名而定,要求这个类里面这...
  • StarskyBoy
  • StarskyBoy
  • 2016年08月22日 11:44
  • 2705

Map集合的两种遍历方式

import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Set; pu...
  • Geek_ymv
  • Geek_ymv
  • 2014年03月05日 20:34
  • 4137

函数调用时两种传参方式

函数在调用的时候有两种传参方式:一种是值传递,另一种是引用传递。 值传递:传递的是变量本身的值。一般程序中的值传递都是基本数据类型,如:int、char、double、float、long等等。 ...
  • qq378718095
  • qq378718095
  • 2017年10月18日 20:12
  • 60

自定义异常的两种处理方式实现

public class NewExceptionTest { public void method(String str)throws NewException { if(str==null...
  • u012575573
  • u012575573
  • 2014年05月06日 10:58
  • 312

map的两种遍历方式和区别。

简单点的说:keySet()遍历是先将keys存入Set集合,再遍历该集合中的keys,再用 遍历得到的key取得相应的值 。value= get(key);获得值。 而entrySet()则是把所...
  • jh624
  • jh624
  • 2013年12月11日 01:00
  • 1551

Service的两种启动方式及其之间的区别

作为Android四大组价之一的Service,可以在很多场合中进行应用。比如当在播放音频的时候用户启动了其他Activity,这个时候程序要在后台继续播放,比如检测SD卡上文件的变化,或者在后台记录...
  • siwen1234
  • siwen1234
  • 2015年12月14日 11:37
  • 1511

表单提交的两种方式

表单的中如何获取input等控件的属性值     先获取控件              Document.getElements*******              表单名.控件名    ...
  • web_hua
  • web_hua
  • 2017年09月07日 20:00
  • 186
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:处理事务的两种方式
举报原因:
原因补充:

(最多只允许输入30个字)