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

2016-02-19 16:54 2 1 收藏

今天图老师小编要向大家分享个在C#中使用COM+实现事务控制教程,过程简单易学,相信聪明的你一定能轻松get!

【 tulaoshi.com - 编程语言 】

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

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  一般的数据库事务控制要求事务里所做的操作必须在同一个数据库内,这样在出现错误的时候才能回滚(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 samplepublic 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 databasecompletely");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中。

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

  七:构建客户机

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  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:将控制台程序设置为启动项,然后编译运行,就会看到结果。

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

来源:https://www.tulaoshi.com/n/20160219/1613523.html

延伸阅读
    我感觉声音的播放比较简单。我们从播放声音开始。为什么我这么觉得?我也不知道。 这里是展示最最最最最简单的DirectX播放声音的例子,我尽量省略了无关的代码。最后的代码只有19行,够简单了吧? 准备工作: 1.安装了DirectX SDK(有9个DLL文件)。这里我们只用到MicroSoft.DirectX.dll 和 Microsoft.Directx.DirectSound...
标签: Java JAVA基础
  在jsp程序中使用com组件的机会并不多,jsp也没有直接操作com的函数,但有的工作有时候还必须使用com组件来完成,下面就来说一下具体的操作方法。 在jsp中使用com组件有两种方法:一种是用javascript在客户端来控制(严格说这个应该是html的功能),如:   <OBJECT id="myCom" classid="clsid:9D8A2E2F-D38F-CDAC-D...
对于XML,想必各位都比较了解,我也就不用费笔墨来描述它是什么了,我想在未来的Web开发中XML一定会大放异彩,XML是可扩展标记语言,使用它企业可以制定一套自己的数据格式,数据按照这种格式在网络中传输然后再通过XSLT将数据转换成用户期望的样子表示出来,这样便轻易的解决了数据格式不兼容的问题。用于Internet的数据传输,我想,这是X...
在C#是一种类似 Java 的完全面向对象的高级编程语言,其处理过程采用事件驱动方式,但在实际的使用过程中,有时候通过调用系统原有的消息处理起来会更简单,特别是在处理与DLL文件的交互时,实践证明的确是非常方便的。 在C#中使用自定义消息 在C#中使用自定义消息非常简单,只需要下面几个简单的步骤就可以了: 1、定义消...
在做C/S三层结构之前,对Com+了解甚少,由于客户中途要求将两层结构改为三层结构(客户端+中间层+后台数据库),所以不得不狂看Com+相关的文档。经过两天的资料查找、文档阅读和反复试验,已基本了解Com+原理,并成功实现三层结构模型。 在三层结构的实现过程中,最为关键的是要实现中间层组件在服务器上的运行,即客户端如何调用服务器上...

经验教程

730

收藏

11
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部