网站导航免费论文 原创论文 论文搜索 原创论文 网学软件 学术大家 资料中心 会员中心 问题解答 原创论文 论文素材 设计下载 最新论文 下载排行 论文上传 在线投稿 联系我们
返回网学首页
网学联系
最新论文 推荐专题 热门论文 素材专题
当前位置: 网学 > 编程文档 > C# > 正文
在C#中使用COM+实现事务控制
来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/14
下载{$ArticleTitle}原创论文样式

.NET技术是微软大力推广的下一代平台技术,自从.NET技术架构Beta2版本的正式发布,此项技术也逐渐走向成熟和稳定。按照微软的平台系统占有率,我们不难想象得到,在未来的一两年内.NET技术必定会势如破竹一般的登上主流的技术平台,而一个新的技术平台得以快速发展的最重要的前提是:他不会彻底的摒弃以前的技术,这一点对于.NET技术来说指的就是COM/COM+技术了。


一般来说,在IT技术界以及硬件产业,技术的更新换代速度非常得惊人,而惯例是所有的新技术都会遵循向下兼容的原则,但是.NET技术不仅仅做到了这一点,.NET甚至实现了相互之间的各自调用,这一点是非常难能可贵的。也就是说,不但我们可以在.NET组件中调用COM组件,同时也可以在COM组件中正常的调用.NET组件。这点带来的好处是显而易见的,一方面我们可以保持现有的技术资源,另一方面,在现有资源中可以利用.NET所带来的各种新技术。


一般的数据库事务控制要求事务里所做的操作必须在同一个数据库内,这样在出现错误的时候才能回滚(RllBack)到初始状态。这就存在一个问题,在分布式应用程序中,我们往往需要同时操作多个数据库,使用数据库本身的事务处理,很难满足程序对事务控制的要求。在COM+中,提供了完整的事务服务,我们可以利用它来完成在分布式应用程序中的事务控制。


具体过程如下


一:用VS.NET生成一个类库 。


二:添加对System.EnterpristServices的引用,具体步骤

菜单:(项目-添加引用-在.NET选项卡选择System.EnterpristServices-确定)


三:构建类


1:源程序


using System;

using System.EnterpriseServices;

using System.Data.SqlClient;

using System.Reflection;


namespace COMPlusSamples

{

//表明需要事务支持

[ Transaction(TransactionOption.Required) ]

//声明为服务器应用程序,还可以选择Library,表示为库应用程序

[assembly: ApplicationActivation(ActivationOption.Server)]

//描述信息

[assembly: Description("sample")]


public class TxCfgClass : ServicedComponent

{

private static string init1 = "user id=sa;password=;initial catalog=pubs;data source=(local)";


private static string init2 = "user id=sa;password=;initial catalog=NorthWind;data source=(local)";


private static string add1 = "insert into authors(''au_lname'',''au_fname'') values(''test1'', ''test2'')";



private static string add2 = "insert into sample values(''test1'',22)";

//the error sql statement

//there is not table “sample”


public TxCfgClass() {}


private void ExecSQL(string init, string sql)

{

SqlConnection conn = new SqlConnection(init);

SqlCommand cmd = conn.CreateCommand();

cmd.CommandText = sql;

conn.Open();

cmd.ExecuteNonQuery();

conn.Close();

}


//添加一条记录到数据库

public void Add()

{

try

{

//在一数据库中插入一条记录


ExecSQL(init1, add1);

Console.WriteLine("the operation in the same database completely");


//在另外一个数据库中插入两条记录

//这次执行的是一个错误的SQL语句


ExecSQL(init2, add2);

Console.WriteLine("the operation in the other database

completely");


Console.WriteLine("Record(s) added, press enter");

Console.Read();


}

catch(Exception e)

{

//事务回滚

ContextUtil.SetAbort();

Console.WriteLine("Because there are some errors in the operation ,so transcation abort");

Console.WriteLine("The error is " + e.Message);

Console.WriteLine("abo
  • 上一篇资讯: c#中构建异常处理
  • 下一篇资讯: 用C#创建COM对象
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号