0

我编写了一些基本代码来解析 CSV 文件并在运行时将数据输入数据库。此代码的变体(针对不同的分隔符和列)对于许多 csv 文件都运行良好,但是由于某种原因,现在此代码给我一个 2 列文件的错误。

using (StreamReader reader = new StreamReader(@"C:\Rawdata\Salesman.csv"))
{
    string line;
    StringBuilder query = new StringBuilder();

    while (!reader.EndOfStream)
    {
        line = reader.ReadLine();
        StringBuilder segment = new StringBuilder();

        for (int i = 0, segno = 0; i < line.Length; i++)
        {
            if (line[i] != '\t')
            {
                segment.Append(line[i]);
            }
            else
            {
                switch (segno)
                {
                    case 0:
                        cmd.Parameters.Clear();
                        cmd.Parameters.AddWithValue("@code", segment.ToString());

                        break;
                    case 1:
                        cmd.Parameters.AddWithValue("@name", segment.ToString());
                        break;
                    default:
                        break;
                }
                segno++;
                segment.Clear();
            }
        }

        delCmd = "INSERT INTO sales_codes (code, name) VALUES (@code, @name)";
        cmd.CommandText = delCmd;

        cmd.ExecuteNonQuery();

        query.Clear();
    }
}

抛出的异常是:

SqlCeException - A parameter is missing. [ Parameter ordinal = 1 ]

我已经仔细检查了从文件、代码到表模式的所有内容,一切看起来都很好。我错过了什么?

4

1 回答 1

1

就像现在一样,您的代码只会在\t找到选项卡 ( ) 时添加参数。如果每行不以制表符结尾,则不会添加第二个参数。这可能是你的问题。

于 2012-08-28T14:04:27.427 回答