在中使用实现事务控制牛

干燥设备2021年09月06日

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

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

一般的数据库事务控制要求事务里所做的操作必须在同一个数据库内,这样在出现错误的时候才能回滚(RllBack)到初始状态。这就存在一个问题,在分布式应用程序中,我们往往需要同时操作多个数据库,使用数据库本身的事务处理,很难满足程序对事务控制的要求。在COM+中,提供了完整的事务服务,我们可以利用它来完成在分布式应用程序中的事务控制。

具体过程如下

一:用生成一个类库 。

二:添加对terpristServices的引用,具体步骤

菜单:(项目-添加引用-在.NET选项卡选择terpristServices-确定)

三:构建类

1:源程序

using System;

using terpriseServices;

using lClient;

using flection;

namespace COMPlusSamples

{

//表明需要事务支持

[ Transaction(quired) ]

//声明为服务器应用程序,还可以选择Library,表示为库应用程序

[assembly: ApplicationActivation(rver)]

//描述信息

[assembly: Description(\"sample\")]

public class TxCfgClass : ServicedComponent

{

泰特利物浦将举行杰克逊·波洛克大型个展《盲点》(Blind Spots) 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 = eateCommand();

mandText = sql;

en();

ecuteNonQuery();

ose();

}

//添加一条记录到数据库

public void Add()

{

try

{

//在一数据库中插入一条记录

ExecSQL(init1, add1);

iteLine(\"the operation in the same database completely\");

//在另外一个数据库中插入两条记录

//这次执行的是一个错误的SQL语句

ExecSQL(init2, add2);

iteLine(\"the operation in the other database

completely\");

iteLine(\"Record(s) added, press enter...\");

ad();

}

catch(Exception e)

{

//事务回滚

tAbort();

iteLine(\"Because there are some errors in the operation ,so transcation abort\");

iteLine(\"The error is \" + ssage);

iteLine(\"abort successfully\");

ad();

}

}

}

}

郑州看白癜风专科医院
海口治疗子宫内膜炎费用
菏泽较好的白癜风医院
相关阅读
盈盈同在,气象万千。

其他用户" 漳州纤日常生活 "注目我 由此可知 读 先贤之外以陋室为品,一间...

2024-12-16
凯特生母被发现,同一款西装有不同颜色!

从名人与潮流博主脖子去追寻脱下搭车启发,对于不少人来说是极其快速且才...

2024-10-12
瑞典 贵丰/Gryphon Ethos(思潮) 新款旗舰CD机

当您第一眼看到贵丰/Gryphon Ethos(时代精神)时一定会被其出色的外观设计所...

2024-07-23
吴彦祖近照曝光,妻女妻女参加首映礼,女儿打耳洞染红发好有个性

近来,陈彦祖携妻子Lisa和妹妹陈斐然参加《东北部世界》第四季首映式。陈...

2024-07-04
Ulster霍尔大学优质课程推荐 BSc Nursing Science (Top-up) & MS

弗莱明所大学(Ulster University)位于苏格兰波斯尼亚和黑塞哥维那尔兰东南部贝...

2024-06-22
一美演技爆表的片子——《分裂》(上)

陌生人似乎地拉低上衣,想盖住盲目性感的丝袜,一美注意到却怒了 (你来...

2024-05-31
友情链接