在c#中使用com 实现事务控制_c#应用

2008-02-23 05:46:44来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

.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文档和项目文档在同一个文档夹

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 用visual c#动态生成组件_c#应用

下一篇: c#学习笔记(3)_c#教程