.NET技术登上主流技术平台

开发 后端
这里介绍.NET技术是微软大力推广的下一代平台技术,自从.NET技术架构Beta2版本的正式发布,此项技术也逐渐走向成熟和稳定。

.NET有很多值得学习的地方,这里我们主要介绍.NET技术,包括介绍COM/COM+技术等方面。

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

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

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

具体过程如下

一:用VS.NET生成一个类库

二:添加对System.EnterpristServices的引用,具体步骤
菜单:(项目-添加引用-在.NET选项卡选择System.EnterpristServices-确定)

三:构建类

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();   }   }   }  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.

【编辑推荐】

  1. .NET VS Java平台之争的理性思考
  2. .NET C# DES入门浅析
  3. .NET写入文本文件的操作浅析
  4. .NET自定义控件应该如何实现?
  5. 浅析.NET 4.0和Visual Studio 2010多定向支持
责任编辑:佚名 来源: chinaitlab
相关推荐

2021-02-22 10:32:53

大数据大数据平台大数据技术栈

2009-10-16 16:52:16

电缆布线技术

2009-09-01 16:08:06

主流宽带技术光纤

2009-10-29 08:49:28

无线接入技术

2010-03-18 14:54:46

主流无线技术

2021-01-18 18:15:00

GitHub 技术开发

2011-09-02 09:42:04

.NET平台

2023-01-13 11:27:13

战略平台Forrester

2014-07-28 15:35:27

混搭NET技术

2010-08-09 10:54:30

RIAFlex

2016-03-24 09:43:57

无线通信技术无线技术

2018-03-06 14:44:59

2009-10-29 09:25:18

宽带接入技术

2009-07-29 15:38:01

2009-12-29 15:44:11

ADO.NET检索技术

2021-02-17 10:55:32

XRVRAR

2015-07-23 14:28:04

.NET技术大系

2015-10-28 09:56:43

物联网减肥

2016-03-14 13:14:34

物联网物联网技术

2011-05-19 13:45:38

点赞
收藏

51CTO技术栈公众号