在C#中使用COM+实现事务控制
NET技术是微软大力推广的下一代平台技术 自从 NET技术架构的正式发布 此项技术也逐渐走向成熟和稳定 按照微软的平台系统占有率 我们不难想象得到 在未来的一两年内 NET技术必定会势如破竹一般的登上主流的技术平台 而一个新的技术平台得以快速发展的最重要的前提是 他不会彻底的摒弃以前的技术 这一点对于 NET技术来说指的就是/+技术了
一般来说 在IT技术界以及硬件产业 技术的更新换代速度非常得惊人 而惯例是所有的新技术都会遵循向下兼容的原则 但是 NET技术不仅仅做到了这一点 NET甚至实现了相互之间的各自调用 这一点是非常难能可贵的 也就是说 不但我们可以在 NET组件中调用组件 同时也可以在组件中正常的调用 NET组件 这点带来的好处是显而易见的 一方面我们可以保持现有的技术资源 另一方面 在现有资源中可以利用 NET所带来的各种新技术
一般的数据库事务控制要求事务里所做的操作必须在同一个数据库内 这样在出现错误的时候才能回滚(RllBack)到初始状态 这就存在一个问题 在分布式应用程序中 我们往往需要同时操作多个数据库 使用数据库本身的事务处理 很难满足程序对事务控制的要求 在+中 提供了完整的事务服务 我们可以利用它来完成在分布式应用程序中的事务控制
具体过程如下
一 用VS NET生成一个类库
二 添加对System EnterpristServices的引用 具体步骤
菜单 (项目-添加引用-在 NET选项卡选择System EnterpristServices-确定)
三 构建类
源程序
using System; using System EnterpriseServices; using System Data SqlClient; using System Reflection; namespace PlusSamples { //表明需要事务支持 [ Transaction(TransactionOption Required) ] //声明为服务器应用程序 还可以选择Library 表示为库应用程序 [assembly: ApplicationActivation(ActivationOption Server)] //描述信息 [assembly: Description( sample )] public class TxCfgClass : ServicedComponent { private static string init = user id=sa;password=;initial catalog=pubs;data source=(local) ; private static string init = user id=sa;password=;initial catalog=NorthWind;data source=(local) ; private static string add = insert into authors( au_lname au_fname ) values( test test ) ; private static string add = insert into sample values( test ) ; //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(init add ); Console WriteLine( the operation in the same database pletely ); //在另外一个数据库中插入两条记录 //这次执行的是一个错误的SQL语句 ExecSQL(init add ); Console WriteLine( the operation in the other databasepletely ); 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(); } } } }
程序说明
添加命名空间 using System EnterpriseServices;因为本程序使用了其中的ContextUtil类
[ Transaction(TransactionOption Required) ] 说明DLL需要事务支持
本程序的TxCfgClass 类从ServicedComponent类中继承 这样并不会影响该类 而只是在该类中添加了两个额外的方法 这两个方法可以使代码共享变得更加容易
程序使用的sql server数据库在本机运行 init 和 init 是两个连接数据库的连接字符串 init连接pubs数据库 inin 连接northwind数据库 这是sql 中自带的示例数据库 add 和add 是两条sql语句 作用是分别向两个数据库的表里添加一条记录 注意 add 是一条错误的语句 因为根本没有sample表 这样 会在执行时引起异常 (这正是我们所期望的)
在执行到add 语句时 由于它是错误的 所以会引发异常 转到错误处理语句里来执行
ContextUtil SetAbort();该语句使所有的数据库操作回滚 这样add 语句所插入的记录也将不存在 (达到预期目标)
四 给程序添加强名(strong name)
创建一对密钥
用来创建密钥的工具是称为sn exe的共享工具 通常通过命令提示运行它 该工具可执行各种任务以生成并提取密钥 我们需要用以下方式来运行sn exe
sn –k key snk
其中key snk 代表将保存密钥的文件的名称 它的名称可以是任意的 不过习惯上带有 snk后缀名
签名
签名通常是在编译时进行的 签名时 用户可利用C#属性通知编译器应该使用正确的密钥文件对DLL进行签名 要做到这一点用户需要打开工程中的AssemblyInfo cs文件并进行修改
[assembly:AssemblyKeyFile( \\ \\key snk )]
注 key snk文件和项目文件在同一个文件夹
五 编译成DLL (具体步骤)
菜单 (生成-生成)
如果一切正常 就会生成DLL文件
六 使用regsvcs exe将Dll注册到+ Services里面
我们需要用以下方式运行regsvcs exe
regsvcs dll文件名
如果一切正常的话 regsvcs exe就会把dll输入到+ Services中
至此 我们已经生成并注册了这个可以由其它程序使用的类 现在 我们来写一个控制台程序来检验这个类是否正常运行
七 构建客户机
新建控制台应用程序项目
菜单(文件-新建-项目)
选择控制台应用程序 并选择 添入解决方案 确定
同上面的第二步一样 添加对System EnterpriseServices的引用
添加对自己刚才做好的类的引用
菜单(项目-添加引用-浏览) 选择刚才生成的DLL 确定
输入以下程序
using System; using PlusSamples; using System EnterpriseServices; public class Client { public static void Main() { TxCfgClass cfg = new TxCfgClass(); cfg Add(); } }
将控制台程序设置为启动项 然后编译运行 就会看到结果
lishixinzhi/Article/program/net/201311/14821