我正在使用c#中的sql批量複製在Excel中填充值。如何在sql批量複製中插入一個具有特定值的列
DataTable dt = new DataTable();
string line = null;
int i = 0;
using (StreamReader sr = File.OpenText(@"c:\temp\table1.csv"))
{
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;
dt.Rows.Add(row);
}
}
}
using (SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["ConsoleApplication3.Properties.Settings.daasConnectionString"].ConnectionString))
{
cn.Open();
using (SqlBulkCopy copy = new SqlBulkCopy(cn))
{
copy.ColumnMappings.Add(0, 0);
copy.ColumnMappings.Add(1, 1);
copy.ColumnMappings.Add(2, 2);
copy.ColumnMappings.Add(3, 3);
copy.ColumnMappings.Add(4, 4);
copy.DestinationTableName = "Censis";
copy.WriteToServer(dt);
}
}
在上面的代碼中,我將記錄從excel插入表中。但是,我在Censis表中還有一列「ProcessID」。對於每次運行,我需要生成一個GUID並用此填充此列。
任何人可以幫助我如何填充ProcessID列,當我做如上所述的大批量複製與生成的GUID爲該運行的所有行?
你能增加更多細節嗎? – guiomie 2013-06-19 18:09:02