一个Web Service 自动事务的例子

举一个在A和B账户间转账的例子,比较简单:

 

using  System;
using  System.Web;
using  System.Web.Services;
using  System.Web.Services.Protocols;
using  System.EnterpriseServices;     // 用于支持事务
using  System.Data.SqlClient;          // 用于数据库操作

[WebService(Namespace 
=   " http://tempuri.org/ " )]
[WebServiceBinding(ConformsTo 
=  WsiProfiles.BasicProfile1_1)]
public   class  Service : System.Web.Services.WebService
...
{
    
public Service () ...{

        
//如果使用设计的组件,请取消注释以下行 
        
//InitializeComponent(); 
    }


    [WebMethod(TransactionOption 
= TransactionOption.RequiresNew)]
    
public string TransferMoneyFromAToB(int m)
    ...
{
        
try
        ...
{
            ContextUtil.EnableCommit();
            
this.TransferOutFromA(m);
            
this.TransferInToB(m);
            ContextUtil.SetComplete();
            
return "搞定!";
        }

        
catch (Exception e)
        ...
{
            ContextUtil.SetAbort();
            
return "糟糕!"+e.Message;
        }

    }

    
private void TransferOutFromA(int num)
    ...
{
        SqlConnection conn 
= new SqlConnection("server=.;database=Account;uid=sa;pwd=;");
        conn.Open();
        SqlCommand sc 
= new SqlCommand("update AccountTransfer set money=money-"+num+" where accountname='A'",conn);
        sc.ExecuteNonQuery();
        conn.Close();
        
//throw new Exception("机器出现故障,抱歉!");                        //*****************
    }

    
private void TransferInToB(int num)
    ...
{
        SqlConnection conn 
= new SqlConnection("server=.;database=Account;uid=sa;pwd=;");
        conn.Open();
        SqlCommand sc 
= new SqlCommand("update AccountTransfer set money=money+"+num+" where accountname='B'",conn);
        sc.ExecuteNonQuery();
        conn.Close();
    }

}
 

 

这个例子是以POST方式调用的,当然也可以通过代理以SOAP方式调用,这里就不再举例了。至于这里的事务操作,保证了划转双方金额增减同时进行,当机器出现故障时,回滚操作,不至于一方扣钱了而另一方钱没加上的状况。大家可将注释* 的行添上试试看。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值