C# 在行上使用foreach循环时发生SSIS脚本组件错误
我有以下脚本组件,它们将所有数据放在特定的列标题案例中。 除此之外,我想通过将某些地址后缀转换为大写来格式化它们。当我添加C# 在行上使用foreach循环时发生SSIS脚本组件错误,c#,ssis,C#,Ssis,我有以下脚本组件,它们将所有数据放在特定的列标题案例中。 除此之外,我想通过将某些地址后缀转换为大写来格式化它们。当我添加foreach循环时,如何得到以下错误: 错误:数据流任务处的0xC0202009,SQL Server目标[302]: SSIS错误代码DTS_E_OLEDBERROR。发生OLE DB错误。错误代码:0x80040E14。 OLE DB记录可用。来源:“Microsoft SQL Server本机客户端11.0”Hresult:0x80040E14说明:“无法从链接服务器
foreach
循环时,如何得到以下错误:
错误:数据流任务处的0xC0202009,SQL Server目标[302]:
SSIS错误代码DTS_E_OLEDBERROR。发生OLE DB错误。错误代码:0x80040E14。
OLE DB记录可用。来源:“Microsoft SQL Server本机客户端11.0”Hresult:0x80040E14说明:“无法从链接服务器的OLE DB提供程序“大容量”中获取行”(null)”*
我减少了目标任务流上的超时设置,并减少了MaxCommitSize
,但似乎什么都不起作用。当我删除循环时,流程就开始工作了
代码:
公共静态字符串StringInput(字符串输入)
{
TextInfo tCase=新文化信息(“en-US”,false);
返回tCase.ToTitleCase(Regex.Replace(input.ToLower(),@“\s+”,”);
}
公共静态列表地址后缀=新列表();
公共覆盖无效Input0\u进程InputRow(Input0Buffer行)
{
地址后缀。添加(“Sw”);
地址后缀。添加(“Nw”);
地址后缀。添加(“Ne”);
地址后缀。添加(“Se”);
如果(!Row.STREET1_为空)
{
foreach(AddressSuffix中的字符串后缀)
{
if(StringInput(Row.STREET1)=后缀)
{
Row.STREET1=StringInput(Row.STREET1.ToUpper();
}
其他的
{
Row.STREET1=StringInput(Row.STREET1);
}
}
}
您确定上面的代码会导致提供的错误吗?此代码只会更改当前行中的值。提供的错误是从目标组件生成的。我不确定,但是如果我删除foreach
,则任务正常工作,我可以使用代码的所有其他部分而不出错。只是不确定你认为你的代码在做什么呢?闻起来好像你在试图标准化地址的外观,但我认为你有一些逻辑错误。
public static string StringInput(string input)
{
TextInfo tCase = new CultureInfo("en-US", false).TextInfo;
return tCase.ToTitleCase(Regex.Replace(input.ToLower(), @"\s+", " "));
}
public static List<string> AddressSuffix = new List<string>();
public override void Input0_ProcessInputRow(Input0Buffer Row)
{
AddressSuffix.Add("Sw");
AddressSuffix.Add("Nw");
AddressSuffix.Add("Ne");
AddressSuffix.Add("Se");
if (!Row.STREET1_IsNull)
{
foreach (string suffix in AddressSuffix)
{
if (StringInput(Row.STREET1) == suffix)
{
Row.STREET1 = StringInput(Row.STREET1).ToUpper();
}
else
{
Row.STREET1 = StringInput(Row.STREET1);
}
}
}