通过Visual C#.NET建一个DTS任务

visual

本文描述了如何利用Visual C#.net 创建一个DTS 自定义的任务。你可以通过C#.net创建自定义的任务的方式扩展DTS的功能。之后你可以安装并注册任务,他讲出现在DTS设计其中,就像默认的DTS任务。总之,你能够使用.NET Framework创建自定义的任务。

  在本文中除了讲创建一个DTS自定义任务外,还包括一下部分内容:

  1、这篇文章中自定义的代码分为编译、注册和安装自定义任务;

   2、这部分一个有特色的部分就是你可以运行自定义的任务;

   3、在开发过程中你可以使用本文提及的一些工具(除非另有说明,这些工具已经包含在.NET中了,您可以通过.NET的命令行运行这些工具)。

   为DTSSpkg.dll创建一个及时的包

  如果一个基于微软.NET客户机访问一个COM组件,你必须使用一个包(这个组件包含的)。这类的包是及时的运行包(RCW)并且你也可以通过开放Dtspkg.dll的类型库编译。你也可以使用类型库导出工具(Tlbimp.exe)编译RCW,如:

tlbimp.exe “C:\ProgramFiles\Microsoft SQLServer\80\tools\Binn\dtspkg.dll”/out:Microsoft.SQLServver.DTSPKG80.dll/keyfile:DTSPkg.snk

“/keyfile”参数代表Microsoft.SQLServer.DTSPkg80.dll带有强类型名用public或private关键字。使用强类型名工具(sn.exe)在DTSPkg.snk 前创建关键字:

sn.exe –k DTSPkg.snk

  你应该使用一个强类型名像其他的全局集合缓存,因为你安装了运行包。

  在全局集合缓存中安装运行包

  用全局集合缓存工具(GaCutil.exe)安装运行包:

gacutil.exe /I Microsoft.SQLServer.DTSPkg80.dll

 安装了运行包后,你可以像添加.NETC#工程中的引用一样的添加。
  
  为自定义的任务添加代码

  代码的自定义注册。.NET没有开放DllReginsterServer 和DllUnregisterServer 像COM组件的入口,但是你可以使用ComRegisterFunctionAttribute 类执行任务注册和撤销注册。在自定义类声明之前添加下面代码:

[Guid("A39847F3-5845-4459-A25E-DE73A8E3CD48"), ComVisible(true)]

[ProgId("DTS.SimpleTask")]

public class SimpleTask : CustomTask

{

//implementation of custom task

}

  下面的代码是一个函数注册的范例执行。函数的全部代码在自定义任务的编译、注册和安装部分 。

[System.Runtime.InteropServices.ComRegisterFunctionAttribute()]

static void RegisterServer(Type t)

{

//code to register custom task

}

  注册函数增加下面的键值用来注册。

HKEY_CLASSES_ROOT\CLSID\A39847F3-5845-4459-A25E-DE73A8E3CD48\Implemented Categories\{10020200-EB1C-11CF-AE6E-00AA004A34D5}

10020200-EB1C-11CF-AE6E-00AA004A34D5是DTS包对象的类编号。因为所有的自定义的任务执行自定义的接口所以必须注册。注册函数添加下面的注册键值:

HKEY_CURRENT_USER\Software\Microsoft\Microsoft SQL Server\80\DTS\Enumeration\Tasks\A39847F3-5845-4459-A25E-DE73A8E3CD48

  下面的DTS任务缓存目录列表,使自定义的任务出现在DTS设计器中:

HKEY_CURRENT_USER\Software\Microsoft\Microsoft SQL Server\80\DTS\Enumeration\Tasks\

  下面的代码示范非注册函数的任务移出的执行。面注册函数是ComUnregisterFunctionAttribute类在.NET运行库的一部分。想浏览这个函数的完整代码,你可以看“编译、注册和安装自定义任务”部分:

[System.Runtime.InteropServices.ComUnregisterFunctionAttribute()]

static void UnregisterServer(Type t)

{

//code to unregister custom task

}

  免注册函数通过从注册表中删除下面键值从DTS任务缓存中移出任务

HKEY_CURRENT_USER\Software\Microsoft\Microsoft SQL Server\80\DTS\Enumeration\Tasks\A39847F3-5845-4459-A25E-DE73A8E3CD48

  最后,自定义的任务像dual_interface COM组件一样被开放。您从所有的类的public,非静态的字段,属性和方法创建一个默认的接口。在下面的一行代码在自定义任务源文件中USING应用之后:

[assembly:ClassInterface(ClassInterfaceType.AutoDual)]

  这部分的代码已经完全列举了。

  增加功能性的自定义任务

  本文“编译、注册和安装自定义任务”部分包含一个简单的DTS自定义任务代码。 任务有两个属性:Name 和Description,Description属性的值就会出现在消息框中。这个例子的描述了一个最小化的代码你可以使用已有的功能性的DTS定义任务。然而,你可以通过执行CustomTaskUI接口创建一个用户界面,但是那并不作讨论。通过只执行自定义的接口,DTS设计者为自定义任务创建一个默认的有户界面。

  所有的DTS自定义任务执行自定义任务接口。自定义的用户接口是由两个属性,一个集合和一个方法:

  1、 Name和Description属性;

  2、 Properties集;

  3、 Execute方法。

  所有的自定义任务应该执行属性、属性集和Execute方法。

  编译、注册和安装自定义任务

using System;
using System.Runtime.InteropServices;
using Microsoft.SQLServer.DTSPkg80;
using Microsoft.Win32;
using System.Windows.Forms;

[assembly:ClassInterface(ClassInterfaceType.AutoDual)]

namespace DTS
{
 [Guid("38ED4F80-9EF4-4752-8478-65D2DB3BA7DD"), ComVisible(true)] //GUID is created by using GUIDGEN.EXE
 [ProgId("DTS.SimpleCustomTask")]
 public class SimpleCustomTask : CustomTask
 {
  private string name;
  private string description;
  public SimpleCustomTask()
  {
   name = "";
   description = "SimpleCustomTask description";
  }
  public void Execute(object pPackage, object pPackageEvents, object pPackageLog, ref Microsoft.SQLServer.DTSPkg80.DTSTaskExecResult pTaskResult)

  {
   //Assume failure at the outset
   pTaskResult= DTSTaskExecResult.DTSTaskExecResult_Failure;
   try
   {
   Package2 package = (Package2) pPackage;
   PackageEvents packageEvents = (PackageEvents) pPackageEvents;
   PackageLog packageLog = (PackageLog) pPackageLog;
   MessageBox.Show(description);
   }
   //First catch COM exceptions, and then all other exceptions
   catch(System.Runtime.InteropServices.COMException e)
   {
    Console.WriteLine(e);
   }
   catch(System.Exception e)
   {
    Console.WriteLine(e);
   }

    //Return success
   pTaskResult = DTSTaskExecResult.DTSTaskExecResult_Success;
  }

  public string Description
   {
   get { return this.description; }
   set { this.description = value; }
  }

  public string Name
  {
   get { return name; }
   set { this.name = value; }
  }

  public Microsoft.SQLServer.DTSPkg80.Properties Properties
  {
   get { return null; }
  }

  [System.Runtime.InteropServices.ComVisible(false)]
  override public string ToString()
  {
   return base.ToString();
  }

  //Registration function for custom task.
  [System.Runtime.InteropServices.ComRegisterFunctionAttribute()]
  static void RegisterServer(Type t)
  {
   try
   {
    const string TASK_CACHE = "Software\\Microsoft\\Microsoft SQL Server\\80\\DTS\\Enumeration\\Tasks";
const string CATID_DTSCustomTask = "{10020200-EB1C-11CF-AE6E-00AA004A34D5}";
string guid = "{" + t.GUID.ToString() + "}";
guid = guid.ToUpper();
Console.WriteLine("RegisterServer {0}", guid);
RegistryKey root;
RegistryKey rk;
RegistryKey nrk;
// Add COM Category in HKEY_CLASSES_ROOT

root = Registry.ClassesRoot;
rk = root.OpenSubKey("CLSID\\" + guid + "\\Implemented Categories", true);
nrk = rk.CreateSubKey(CATID_DTSCustomTask);
nrk.Close();
rk.Close();
root.Close();
// Add to DTS Cache in HKEY_CURRENT_USER
root = Registry.CurrentUser;
rk = root.OpenSubKey(TASK_CACHE, true);
nrk = rk.CreateSubKey(guid);
nrk.SetValue("", t.FullName);
nrk.Close();
rk.Close();
root.Close();
SimpleCustomTask ct = new SimpleCustomTask();
  root = Registry.ClassesRoot;
rk = root.OpenSubKey("CLSID\\" + guid, true);
rk.SetValue("DTSTaskDescription", ct.description);
nrk.Close();
  rk.Close();
root.Close();
   }
   catch(Exception e)
   {
    System.Console.WriteLine(e.ToString());
   }
  }

 //Unregistration function for custom task.
 [System.Runtime.InteropServices.ComUnregisterFunctionAttribute()]
 static void UnregisterServer(Type t)
 {
  try
  {
const string TASK_CACHE = "Software\\Microsoft\\Microsoft SQL Server\\80\\DTS\\Enumeration\\Tasks";
string guid = "{" + t.GUID.ToString() + "}";
guid = guid.ToUpper();
Console.WriteLine("UnregisterServer {0}", guid);
RegistryKey root;
RegistryKey rk;
// Delete from DTS Cache in HKEY_CURRENT_USER
root = Registry.CurrentUser;
rk = root.OpenSubKey(TASK_CACHE, true);
rk.DeleteSubKey(guid, false);
rk.Close();
root.Close();
  }
  catch(Exception e)
  {
System.Console.WriteLine(e.ToString());
  }
 }
}

}

时间: 2024-11-18 18:25:53

通过Visual C#.NET建一个DTS任务的相关文章

怎样通过Visual C#.net创建一个DTS任务

visual|创建 怎样通过Visual C#.net创建一个DTS任务一.摘要这篇文章描述了如何利用Visual C#.net 创建一个DTS 自定义的任务.你可以通过C#.net创建自定义的任务的方式扩展DTS的功能.之后你可以安装并注册任务,他讲出现在DTS设计其中,就像默认的DTS任务.总之,你能够使用.NET Framework创建自定义的任务. 这篇文章除了讲创建一个DTS自定义任务外,还包括一下部分内容: 1.这篇文章中自定义的代码分为编译.注册和安装自定义任务:2.这部分一个有特

visual studio 2013建不了源文件

问题描述 visual studio 2013建不了源文件 解决方案 看工程生成的时候是否产生对应的文件.是不是编译器的安装不正确 解决方案二: 贴一个图天知道.你创建的是什么项目,怎么个创建失败,你是怎么操作的.磁盘上有没有产生文件,等等. 不过建议你重装系统,一了百了.另外确认你能使用英文版并且看懂提示. 解决方案三: 因为干净的系统+新装的软件肯定可以100%正常工作.否则就看你的造化了.

【云计算的1024种玩法】为喜欢的人建一个网站

曾几何时,你是不是也为不知道怎么向心爱的人表白而苦恼,书信略显古老,微信稍微有点随意,那么,从今天起,一种高大上的表白方式正式上线阿里云--"为喜欢的人建一个网站".即使您是能够"攻城掠地"的工程师,也会苦于没有后台服务器的支撑,没关系,阿里云服务器ECS为您解忧:也许您是一个非IT行业人士,对网页一无所知,没关系,我们给您提供一整套的服务,您只需要把爱表达出来就行了. 在阿里云服务器的支撑下,搭建一个属于自己的网站.以阿里云服务器ECS为基础,搭建一个网页平台,用

给Win7建一个“常用程序”菜单

很多人都喜欢将常用程序拖拽到桌面上,美其名曰"桌面快捷方式".不过随着使用时间的增加,这个快捷方式似乎也不怎么快捷.没有分类.无法分组,最关键的是当你的桌面布满窗口的时候,要想打开桌面上一个快捷方式,真比登天还难.其实在万能的Win7中,这个问题并没有大家想像中那么难以搞定.今天就教给大家一个办法,给你的Win7建一个"常用程序"菜单. 图1 用菜单访问"常用程序" 电脑常识 1.在电脑的某个位置建立一个文件夹(比如"C:常用程序&qu

有闲-建一个这样的展示网站(主要用作app下载),大概需要多少money ??

问题描述 建一个这样的展示网站(主要用作app下载),大概需要多少money ?? [有闲]网站地址 http://www.youxianapp.com/自学的话,多久能自己做出来求教大神!!

教你三分钟建一个网站,PC端,手机端,微网站

如何建一个三站合一的网站?三站合一的网站一般指手机站.微站和手机站,大多数企业用户的做法是,三大站点分别制作,建站程序不同,管理入口不同,更新内容的时候,一篇文章要分三次发布,更要命的是,建一个手机网站或微网站哪一个不要上万块.免费建网站:http://www. iisp.com/special/design_promotion.php?s=guili147 本文提到建三站合一的方法与上文说到的不一样,我们使用的是建站宝盒.为什么要使用建站宝盒做三站合一的企业网站呢? 三点优势 一套程序,建三个

建表-当我要查询的数据同时在两个表中时,是否应该再建一个新的表?

问题描述 当我要查询的数据同时在两个表中时,是否应该再建一个新的表? 我有一个收入表(表1),一个支出表(表2),然后这样的话就可以对它们进行操作,但是我现在想要查询一个月之内的收支记录,按时间先后排序,我该怎么做呢?我要再建一个表把表1,表2的数据插进去么?还是有别的办法? 解决方案 使用联表连接两个表将两个表的数据同时显示出来或者将两个表的数据查出来后放入到视图当中 解决方案二: 当我每查询一次(当表1,表2更新时)的时候都要先把数据放到视图当中,是不是应该用触发器啊? 解决方案三: 你可以

自带的网站-visual studio 2012 中有一个专门设置roles 和用户的站点在2015中怎么打开

问题描述 visual studio 2012 中有一个专门设置roles 和用户的站点在2015中怎么打开 visual studio 2012 中有一个专门设置roles 和用户的站点在2015中怎么打开? 解决方案 直接打开就可以了,VS2015向下兼容asp.net 4.0 解决方案二: 可以向下兼容的,直接在File中选择打开文件就好了

我想建一个类似萌码的网站,就是那种可以在网页上运行代码的

问题描述 我想建一个类似萌码的网站,就是那种可以在网页上运行代码的 我这两天在逛萌码的时候发现萌码的学习网页很好,我突发奇想也想去做一个能在网页上运行代码的网站, 但是由于本人是个菜鸟,对于关键的那步不太懂,就是如何在后台运行前台的传入的代码并且输出结果呢? 可能我说的不太标准,大家听不懂,但是希望各位大大能帮帮忙研究一下,小菜鸟刚起步,希望多多关照, 谢谢!!!非常感谢! 解决方案 https://github.com/QingdaoU/OnlineJudgehttp://blog.csdn.