C# 通过自定义 UI 设置 SSIS 自定义数据流组件的自定义属性

标签 c# ssis dataflowtask

我在尝试设置通过自定义表单创建的数据流组件的自定义属性时遇到了真正的问题。

我正在分配的值刚刚被设置,自定义属性要么保持原始值,要么保持为空。

在我的 TaskClass 中,我覆盖了 ProvideComponentProperties() 方法并创建了自定义属性,如下所示。

IDTSCustomProperty100 componentCustomProperty = ComponentMetaData.CustomPropertyCollection.New();
componentCustomProperty.Name = "PAFProvider";
componentCustomProperty.Description = "PAF Provider";
componentCustomProperty.Value = "testinitial";

我创建了一个继承自 IDtsComponentUI 接口(interface)的 TaskClassUI。我实现了所有必需的方法。

我的初始化方法。

public void Initialize(IDTSComponentMetaData100 dtsComponentMetadata, IServiceProvider serviceProvider)
{
       this._dtsComponentMetaData = dtsComponentMetadata;
            this._serviceprovider = serviceProvider;

}

我的编辑方法的实现

 public bool Edit(IWin32Window parentWindow, Variables variables, Connections connections)
    {
        bool flag;
        try
        {
            PAFUIMainWnd ui = new PAFUIMainWnd(this._dtsComponentMetaData, this._serviceprovider, connections);
            DialogResult result = ui.ShowDialog(parentWindow);
            bool flag1 = result != DialogResult.OK;
            if(!flag1)
            {
                flag = true;
                return flag;
            }
        }
        catch(Exception exe)
        {
            MessageBox.Show(exe.ToString());
        }
        flag = false;
        return flag;            
    }

以及我的 UIFORM 的实现。

public PAFUIMainWnd(IDTSComponentMetaData100 iDTSComponentMetaData100, IServiceProvider serviceProvider, Connections connections)
        {            
            this.components = null;
            this.InitializeComponent();
            this._dtsComponentMetaData = iDTSComponentMetaData100;     
            this._designTimeComponent = this._dtsComponentMetaData.Instantiate();
            textBox1.Text = _dtsComponentMetaData.CustomPropertyCollection["PAFProvider"].Value.ToString();

        }

出于测试目的,我在表单上添加了一个文本框和一个按钮。甚至按钮的 OnClick 也在下面。我只是从文本框中获取值并将其分配给自定义属性,但它没有分配它。我可以从分配给文本框的自定义属性中读取原始值。我只是不明白为什么我不能分配它。我完全遵循了 MSDN 和其他各种示例。如果有人能指出我做错了什么,我将非常感激。已经到了爆头阶段。

 private void btnOK_Click(object sender, EventArgs e)
    {
       _designTimeComponent.SetComponentProperty("PAFProvider", textBox1.Text);           

        this.Close();
    }

最佳答案

重启解决了这个问题。代码非常好。

关于C# 通过自定义 UI 设置 SSIS 自定义数据流组件的自定义属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13609818/

相关文章:

ssis - 如何在Foreach文件枚举器的FileSpec属性上设置表达式?

mysql - SQL Server 2012 数据集成

c# - 如何在 Linux 和 MacOS 上导入 PKCS#8 - CngKey.Import 不可用

c# - 通过调试器观看整个程序

c# - 正则表达式使用 C# 限制仅第二次出现左括号和右括号

sql - 如何在SSIS中动态映射输入和输出列?

sql-server-2005 - 使用 SSIS 更新表

由于 ODBC 数据流任务错误,SSIS 包在 VS 中有效,但在 SSIS 中无效

c# - 如何创建具有多个 XAML 文件的 WPF 应用程序?