在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在C#中使用COM+实现事务控制
.NET技术是微软大力推广的下一代平台技术,自从.NET技术架构Beta2版本的正式发布, 此项技术也逐渐走向成熟和稳定。按照微软的平台系统占有率,我们不难想象得到, 在未来的一两年内.NET技术必定会势如破竹一般的登上主流的技术平台,而一个新的 技术平台得以快速发展的最重要的前提是:他不会彻底的摒弃以前的技术,这一点对 于.NET技术来说指的就是COM/COM+技术了。
一般来说,在IT技术界以及硬件产业,技术的更新换代速度非常得惊人,而惯例是所 有的新技术都会遵循向下兼容的原则,但是.NET技术不仅仅做到了这一点,.NET甚至 实现了相互之间的各自调用,这一点是非常难能可贵的。也就是说,不但我们可以在 .NET组件中调用COM组件,同时也可以在COM组件中正常的调用.NET组件。这点带 来的好处是显而易见的,一方面我们可以保持现有的技术资源,另一方面,在现有资 源中可以利用.NET所带来的各种新技术。
菜单:(项目-添加引用-在.NET选项卡选择System.EnterpristServices-确定)
using System.EnterpriseServices; using System.Data.SqlClient; using System.Reflection;
{ //表明需要事务支持 [ Transaction(TransactionOption.Required) ] //声明为服务器应用程序,还可以选择Library,表示为库应用程序 [assembly: ApplicationActivation(ActivationOption.Server)] //描述信息 [assembly: Description("sample")]
{ private static string init1 = "user id=sa;password=;initial catalog=pubs;data source=(local)";
private static string add2 = "insert into sample values('test1',22)"; //the error sql statement //there is not table “sample”
{ SqlConnection conn = new SqlConnection(init); SqlCommand cmd = conn.CreateCommand(); cmd.CommandText = sql; conn.Open(); cmd.ExecuteNonQuery(); conn.Close(); }
public void Add() { try { //在一数据库中插入一条记录
Console.WriteLine("the operation in the same database completely");
//这次执行的是一个错误的SQL语句
Console.WriteLine("the operation in the other database completely");
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语句所插入的记录也 将不存在。(达到预期目标)
1:创建一对密钥 用来创建密钥的工具是称为sn.exe的共享工具。通常通过命令提示运行它,该工具可执 行各种任务以生成并提取密钥。我们需要用以下方式来运行sn.exe。 sn –k key.snk 其中key.snk 代表将保存密钥的文件的名称。它的名称可以是任意的,不过习惯上带有 .snk后缀名。 2:签名 签名通常是在编译时进行的。签名时,用户可利用C#属性通知编译器应该使用正确的 密钥文件对DLL进行签名。要做到这一点用户需要打开工程中的AssemblyInfo.cs文件 并进行修改。 [assembly:AssemblyKeyFile(“..\\..\\key.snk”)] 注:key.snk文件和项目文件在同一个文件夹
菜单:(生成-生成) 如果一切正常,就会生成DLL文件
我们需要用以下方式运行regsvcs.exe regsvcs dll文件名 如果一切正常的话,regsvcs.exe就会把dll输入到COM+ Services中。
1:新建控制台应用程序项目 菜单(文件-新建-项目) 选择控制台应用程序 ,并选择 添入解决方案 ,确定 2:同上面的第二步一样,添加对System.EnterpriseServices的引用。 3:添加对自己刚才做好的类的引用。 菜单(项目-添加引用-浏览),选择刚才生成的DLL,确定 4:输入以下程序 using System; using COMPlusSamples; using System.EnterpriseServices;
{ public static void Main() { TxCfgClass cfg = new TxCfgClass(); cfg.Add(); } }
正如我们希望的,第一条记录没有插入数据库 |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论