网站导航免费论文 原创论文 论文搜索 原创论文 网学软件 学术大家 资料中心 会员中心 问题解答 原创论文 论文素材 设计下载 最新论文 下载排行 论文上传 在线投稿 联系我们
返回网学首页
网学联系
最新论文 推荐专题 热门论文 素材专题
当前位置: 网学 > 编程文档 > C# > 正文
通过Visual C#.NET建一个DTS任务
来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/14
下载{$ArticleTitle}原创论文样式
ation\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\\Microsof

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号