SSIS自定义数据流组件开发(血路)

由于特殊的原因(怎么特殊不解释),需要开发自定义数据流组件处理。

查了很多资料,用了不同的版本,发现各种各样的问题没有找到最终的解决方案。

遇到的问题如下:

用VS2015编译出来的插件,在SSDTBI(其实也是集成在VS中用于开发SSIS包的) 2015版本中dubug时会提示:

错误 Validation error. Data Flow Task test_displayName [85]: System.MissingMethodException:
找不到方法:“
Microsoft.SqlServer.Dts.Pipeline.Wrapper.IDTSComponentMetaData100
Microsoft.SqlServer.Dts.Pipeline.PipelineComponent.get_ComponentMetaData()”。
在 Genius.SsisModule.DataFlow.GetSeqs.AcquireConnections(Object transaction)
在 Microsoft.SqlServer.Dts.Pipeline.ManagedComponentHost.HostAcquireConnections(IDTSManagedComponentWrapper100 wrapper, Object transaction) Package.dtsx 0

注意这里的红色部分,我反编译了Microsoft.SqlServer.Dts.Pipeline.PipelineComponent类,发现是在访问ComponentMetaData属性时候,内部调用的一个方法。无解!!!

解决办法:

项目那里右键-属性,然后将目标数据库版本从SQL SERVER 2016 改为SQL SERVER 2014 。现在可以正常调试了

SSIS自定义数据流组件开发(血路)

然后把SSDTBI工具换成2013,会提示:

[自定义数据流入库组件 [83]] Error: System.InvalidCastException: 无法将类型为“System.__ComObject”的 COM 对象强制转换为接口类型“Microsoft.SqlServer.Dts.Pipeline.Wrapper.IDTSComponentMetaData100”。此操作失败的原因是对 IID 为“{BE8C48A3-155B-4810-BA5C-BDF68A659E9E}”的接口的 COM 组件调用 QueryInterface 因以下错误而失败: 不支持此接口 (异常来自 HRESULT:0x80004002 (E_NOINTERFACE))。
在 System.StubHelpers.StubHelpers.GetCOMIPFromRCW(Object objSrc, IntPtr pCPCMD, IntPtr& ppTarget, Boolean& pfNeedsRelease)
在 Microsoft.SqlServer.Dts.Pipeline.Wrapper.IDTSComponentMetaData100.get_Name()
在 Genius.SsisModule.SsisModule.BasicComponent.ProcessInput(Int32 inputID, PipelineBuffer buffer)
在 Microsoft.SqlServer.Dts.Pipeline.ManagedComponentHost.HostProcessInput(IDTSManagedComponentWrapper100 wrapper, Int32 inputID, IDTSBuffer100 pDTSBuffer, IntPtr bufferWirePacket)

然后把VS换成2010编译插件,在SSDTBI2013中会提示“null"值对于”Stream“无效

然后把VS换成2010编译插件,在SSDTBI2015中会现XXXXX(忘记具体什么错误了)

就这件事我已经折腾了4天了,能找到的资源非常少,各种版本的VS和SSDTBI都差不多试过了。。

就在快要放弃的时候,发现用VS2015编译的插件,虽然在SSDTBI2015中debug的时候会出现,但包用dtexec 工具调用的时候可以正常执行。

如: dtexec /f "D:\SsisPkg\c.dtsx"

所以最终都使用2015进行处理!

-XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX分隔线XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX-

下面内容是将是我成功执行的记录

-XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX分隔线XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX-

上一篇:红帽Linux故障定位技术详解与实例(2)


下一篇:URAL 6089 Nine