Вставка в SQL через sqlbulk

Привет, у меня есть этот фрагмент кода, как это:

 public static void Put_CSVtoSQL_Adhesion()
    {
        bool IsFirst = true;      
        DataTable dt = new DataTable();
        string line = null;
        int i = 0;

        try
        {
            string fileName = Path.Combine(HttpContext.Current.Server.MapPath(UploadDirectory), TheFileName);

            using (StreamReader sr = File.OpenText(fileName))
            {
                while ((line = sr.ReadLine()) != null)
                {
                    string[] data = line.Split(';');
                    if (data.Length > 0)
                    {
                        if (i == 0)
                        {
                            foreach (var item in data)
                            {
                                dt.Columns.Add(new DataColumn());
                            }
                            i++;
                        }
                        DataRow row = dt.NewRow();
                        row.ItemArray = data;

                        // Pour enlever la tete 
                        if (!IsFirst) dt.Rows.Add(row);
                        IsFirst = false;
                    }
                }
            }

            using (var connectionWrapper = new Connexion())
            {
                var connectedConnection = connectionWrapper.GetConnected();
                using (SqlBulkCopy copy = new SqlBulkCopy(connectionWrapper.conn))
                {
                    int CountColl = dt.Columns.Count;

                    copy.ColumnMappings.Add(0, 1);
                    copy.ColumnMappings.Add(1, 2);
                    copy.ColumnMappings.Add(2, 3);
                    copy.ColumnMappings.Add(3, 4);
                    copy.ColumnMappings.Add(4, 5);


                    copy.DestinationTableName = "cotisation";
                    copy.WriteToServer(dt);
                }
            }
        }
        catch (Exception excThrown)
        {
            throw new Exception(excThrown.Message);
        }
    }

этот код работает хорошо, но теперь у меня более 60 столбцов, нужно ли вводить вручную от 1 до 60 столбцов или есть другой метод?

 copy.ColumnMappings.Add(0, 1);
                    copy.ColumnMappings.Add(1, 2);
                    copy.ColumnMappings.Add(2, 3);
                    copy.ColumnMappings.Add(3, 4);
                    copy.ColumnMappings.Add(4, 5);

... до 60 колонны?

столбец все тот же, я просто сместил 1 столбец, потому что первый столбец автоинкрементируется как идентификатор

1 ответ

Решение

Написать цикл?

for (int i = 0; i < dt.Columns.Count - 1; i++)
{
    copy.ColumnMappings.Add(i, i + 1);
}
Другие вопросы по тегам