一个Web Service 自动事务的例子

原创 2007年10月06日 03:04:00

举一个在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方式调用,这里就不再举例了。至于这里的事务操作,保证了划转双方金额增减同时进行,当机器出现故障时,回滚操作,不至于一方扣钱了而另一方钱没加上的状况。大家可将注释* 的行添上试试看。

一个Web Service 自动事务的例子

举一个在A和B账户间转账的例子,比较简单: using System;using System.Web;using System.Web.Services;using System.Web.Servi...
  • andylaufzf
  • andylaufzf
  • 2007年10月08日 09:26
  • 379

WebService自动事务

[WebMethod(TransactionOption=TransactionOption.RequiresNew)] 
  • amwicfai
  • amwicfai
  • 2007年02月09日 13:49
  • 415

JAVA web编程经验之: 一个请求一个事务

对于一个web请求,你会开启几个事务呢? 或许你没注意过吧. 又或许你不会对代码,性能要求太高,所以.... 一个请求一个事务, 因为一个事务往往和一个数据库连接关联, 如果开启了多个事务的话,也...
  • monkeyking1987
  • monkeyking1987
  • 2014年07月08日 16:52
  • 2736

Web Service入门简介(一个简单的WebService示例)

一、Web Service简介 1.1、Web Service基本概念 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intra...
  • zhongguomao
  • zhongguomao
  • 2017年04月28日 16:16
  • 1039

一个简单的Spring4和MyBatis事务的例子(很详细)

根据维基百科,数据库事务应该具有all-or-nothing原则,无论何时,数据库中的任何工作单元要么全部完成,要么没有任何影响。进一步来说,系统必须将每个事务与其他事务隔离开来,结果必须遵循现有的限...
  • aqzwss
  • aqzwss
  • 2015年03月25日 17:24
  • 2440

一个Web Service的例子

Web服务例子(自己写的,好像在给自己做宣传,不过,暂时没别的例子可说只好将就):http://www26.brinkster.com/ipservices/ip.asmx,这个services就干一...
  • herofour444
  • herofour444
  • 2004年08月01日 00:56
  • 872

一个Web Service的例子

Web服务例子(自己写的,好像在给自己做宣传,不过,暂时没别的例子可说只好将就):http://www26.brinkster.com/ipservices/ip.asmx,这个services就干一...
  • dawave
  • dawave
  • 2004年06月30日 21:23
  • 1673

JDBC ORACLE 简单的事务例子

使用JDBC连接ORACLE,初级的演示事务执行。 JDBC事务定义级别分为五类: TRANSACTION_NONE: TRANSACTION_READ_UNCOMMITED: TRANSAC...
  • hadooptech
  • hadooptech
  • 2012年08月14日 14:58
  • 2541

业务中场景中,调用多个service,事务处理中要注意的问题

在业务层:service中,经常会发生一个操作调用多个service的情况。此时,事务的定义和处理需要注意以下几个关键点: 场景描述: 在A类中循环调用B类的 methodB,B类中包含对其他C, D...
  • fyxxq
  • fyxxq
  • 2014年11月27日 20:56
  • 11829

spring 事务注意事项 -- 事务注解一定写到service最外层

事务采用的是注解方式。 持久层用的是MyBatis,简单配置如下: id="mysqlDataSource" class="com.alibaba.druid.pool.DruidData...
  • wanggang19840529
  • wanggang19840529
  • 2016年08月10日 16:57
  • 1766
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个Web Service 自动事务的例子
举报原因:
原因补充:

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