频道直达 - 学院 - 下载 - 交易 - 特效 - 字库 - 手册 -排名-工具- 繁體
网页教学网站开发 设为首页
加入收藏
联系我们
建站搜索: 常用广告代码   用户注册 | 用户登陆
您当前的位置:中国建站之家 -> 网站开发设计技术教程 -> Asp.Net教程 -> 在C#中使用COM+实现事务控制

在C#中使用COM+实现事务控制

作者:未知  来源:转载  发布时间:2005-9-18 0:42:05  发布人:acx

减小字体 增大字体

.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("abort successfully");

Console.Read();

}

}

}

}

2:程序说明:

添加命名空间 using System.EnterpriseServices;因为本程序使用了其中的ContextUtil类

[ Transaction(TransactionOption.Required) ] 说明DLL需要事务支持

本程序的TxCfgClass 类从ServicedComponent类中继承,这样并不会影响该类,而只是在该类中添加了两个额外的方法,这两个方法可以使代码共享变得更加容易

程序使用的sql server数据库在本机运行,init1 和 init2是两个连接数据库的连接字符串,init连接pubs数据库,inin2连接northwind数据库,这是sql2000中自带的示例数据库。add1和add2是两条sql语句,作用是分别向两个数据库的表里添加一条记录。注意:add2是一条错误的语句,因为根本没有sample表,这样,会在执行时引起异常。(这正是我们所期望的)

在执行到add2语句时,由于它是错误的,所以会引发异常,转到错误处理语句里来执行。

ContextUtil.SetAbort();该语句使所有的数据库操作回滚,这样add1语句所插入的记录也将不存在。(达到预期目标)

四:给程序添加强名(strong name)

1:创建一对密钥

用来创建密钥的工具是称为sn.exe的共享工具。通常通过命令提示运行它,该工具可执行各种任务以生成并提取密钥。我们需要用以下方式来运行sn.exe。

sn –k key.snk

其中key.snk 代表将保存密钥的文件的名称。它的名称可以是任意的,不过习惯上带有.snk后缀名。

2:签名

签名通常是在编译时进行的。签名时,用户可利用C#属性通知编译器应该使用正确的密钥文件对DLL进行签名。要做到这一点用户需要打开工程中的AssemblyInfo.cs文件并进行修改。

[assembly:AssemblyKeyFile(“..\\..\\key.snk”)]

注:key.snk文件和项目文件在同一个文件夹

五:编译成DLL (具体步骤)

菜单:(生成-生成)

如果一切正常,就会生成DLL文件

六:使用regsvcs.exe将Dll注册到COM+ Services里面

我们需要用以下方式运行regsvcs.exe

regsvcs dll文件名

如果一切正常的话,regsvcs.exe就会把dll输入到COM+ Services中。

至此,我们已经生成并注册了这个可以由其它程序使用的类,现在,我们来写一个控制台程序来检验这个类是否正常运行

七:构建客户机

1:新建控制台应用程序项目

菜单(文件-新建-项目)

选择控制台应用程序 ,并选择 添入解决方案 ,确定

2:同上面的第二步一样,添加对System.EnterpriseServices的引用。

3:添加对自己刚才做好的类的引用。

菜单(项目-添加引用-浏览),选择刚才生成的DLL,确定

4:输入以下程序

using System;

using COMPlusSamples;

using System.EnterpriseServices;

public class Client

{

public static void Main()

{

TxCfgClass cfg = new TxCfgClass();

cfg.Add();

}

}

5:将控制台程序设置为启动项,然后编译运行,就会看到结果。

正如我们希望的,第一条记录没有插入数据库


将本文收藏到QQ书签与更多好友分享
[打 印]
[] [返回上一页] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
精彩推荐
热门文章
· 注册码大全二
· 注册码大全四
· 注册码大全一
· 要10G免费网络硬盘的请进..
· 通过google 赶快来赚美金..
· 注册码大全十
· 头像-qq头像(qq新头像)4..
· 让你轻松架设FTP服务器1..
· 注册码大全三
· 梦幻背景图片7
· 卡通动物图片6
· 网页制作素材-按钮素材2..
· 让你轻松架设FTP服务器5..
· 风景图片8
· 注册码大全九
· 让你轻松架设FTP服务器2..
关注此文读者还看过
· 月入千美金不是梦--AdSe..
· 餐具—素材8
· FW MX和Flash MX的亲密合..
· ASP使用Filter实现信息的..
· 输入显示框中循环出现文..
· Webmail攻防实战(4)
· 聚合函数
· 李国庆:6亿美金也不卖当..
· 太平洋网站可能近期上市..
· 一个用Wsh来控制SqlServ..
· 熊猫烧香作者成长轨迹 工..
· 关于SQL Server中几个未..
· asp+与asp的区别(1)
· Dreamweaver8创建自定义..
· Flash MX2004入门与进阶..
· 时髦的Back Button
相关文章
· 在ASP中使用事务控制
· 在ASP中使用事务控制
· 在C#中使用XML指南之读取XM..
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 人才招聘
网站合作、内容监督、商务咨询:QQ: 9576619
Copyright ? 2005--2008 中国建站之家版权所有
粤ICP备05092265号