在 SSIS 脚本组件中将 (XML)String 转换为 DT_NTEXT
Converting a (XML)String to DT_NTEXT inside a SSIS Script Component
嘿,我对来自 Json 的巨大字符串有很大的疑问。我想使用脚本组件将它写入 Nvarchar(max) 列。
OutputColumn 设置为 DT_NTEXT,我正在使用:
Output0Buffer.xdata.AddBlobData(System.Text.Unicode.UTF8.GetBytes(item.x_data));
Json类项目x_data是字符串:
... public string x_data { get; set; } ...
字符串是一个 XML,看起来像这样:
"<products>\r\n <product>\r\n <set>\r\n <pindex>PKHC544</pindex>\r\n <pvarindex><PKHC544><PKHC544.O08.MF1000></pvarindex> \r\n <child>\r\n <index>ZKVXXXXD</index>\r\n <varindex><ZKVXXXXD><ZKVXXXXDD00></varindex>\r\n </child> \r\n </set>\r\n </product>\r\n</products>"
我的错误信息是这样的:
Error: 0xC0047062 at DF Load printcarrier_Orders, SC Import printcarrier_Orders [156]: System.ArgumentNullException: The string reference is not set to a string instance. Parameter name: s for Microsoft.SqlServer.Dts.Pipeline.ScriptComponentHost.HandleUserException(Exception e) at Microsoft.SqlServer.Dts.Pipeline.ScriptComponentHost.PrimeOutput(Int32 outputs, Int32[] outputIDs, PipelineBuffer[] buffers) at Microsoft.SqlServer.Dts.Pipeline.ManagedComponentHost.HostPrimeOutput(IDTSManagedComponentWrapper100 wrapper, Int32 outputs, Int32[] outputIDs, IDTSBuffer100[] buffers, IntPtr ppBufferWirePacket)
我想我对这个字符串的编码有问题,也许 x_data 应该有不同的数据类型。所有其他列都运行顺利。
好的,问题解决了,我之前没有检查空引用。
如果不包含它是行不通的
嘿,我对来自 Json 的巨大字符串有很大的疑问。我想使用脚本组件将它写入 Nvarchar(max) 列。
OutputColumn 设置为 DT_NTEXT,我正在使用:
Output0Buffer.xdata.AddBlobData(System.Text.Unicode.UTF8.GetBytes(item.x_data));
Json类项目x_data是字符串:
... public string x_data { get; set; } ...
字符串是一个 XML,看起来像这样:
"<products>\r\n <product>\r\n <set>\r\n <pindex>PKHC544</pindex>\r\n <pvarindex><PKHC544><PKHC544.O08.MF1000></pvarindex> \r\n <child>\r\n <index>ZKVXXXXD</index>\r\n <varindex><ZKVXXXXD><ZKVXXXXDD00></varindex>\r\n </child> \r\n </set>\r\n </product>\r\n</products>"
我的错误信息是这样的:
Error: 0xC0047062 at DF Load printcarrier_Orders, SC Import printcarrier_Orders [156]: System.ArgumentNullException: The string reference is not set to a string instance. Parameter name: s for Microsoft.SqlServer.Dts.Pipeline.ScriptComponentHost.HandleUserException(Exception e) at Microsoft.SqlServer.Dts.Pipeline.ScriptComponentHost.PrimeOutput(Int32 outputs, Int32[] outputIDs, PipelineBuffer[] buffers) at Microsoft.SqlServer.Dts.Pipeline.ManagedComponentHost.HostPrimeOutput(IDTSManagedComponentWrapper100 wrapper, Int32 outputs, Int32[] outputIDs, IDTSBuffer100[] buffers, IntPtr ppBufferWirePacket)
我想我对这个字符串的编码有问题,也许 x_data 应该有不同的数据类型。所有其他列都运行顺利。
好的,问题解决了,我之前没有检查空引用。 如果不包含它是行不通的