Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/315.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ssis/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 在行上使用foreach循环时发生SSIS脚本组件错误_C#_Ssis - Fatal编程技术网

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);
            }
        }

    }