我有一个名为dt2
. 它包含一些数据。我想将这些数据添加到名为invitationdata
.
我该如何编写代码?任何人都可以帮忙吗?
public bool BulkInsertDataTable(string tableName, DataTable dataTable)
{
bool isSuccuss;
try
{
SqlConnection SqlConnectionObj = GetSQLConnection();
SqlBulkCopy bulkCopy = new SqlBulkCopy(SqlConnectionObj, SqlBulkCopyOptions.TableLock | SqlBulkCopyOptions.FireTriggers | SqlBulkCopyOptions.UseInternalTransaction, null);
bulkCopy.DestinationTableName = tableName;
bulkCopy.WriteToServer(dataTable);
isSuccuss = true;
}
catch (Exception ex)
{
isSuccuss = false;
}
return isSuccuss;
}
DataTable dt = new DataTable();
string sql = "";
for (int i = 0; i < dt2.Rows.Count; i++)
{
sql = sql + "insert into InvitationData (Col1, Col2, ColN) values('"
+ dt2.Rows[i]["columnname"].ToString().Trim() + "','"
+ dt2.Rows[i]["columnname"].ToString().Trim() + "','"
+ dt2.Rows[i]["columnname"].ToString().Trim() + "')";
}
如果您的数据表和表结构相同,那么您可以使用SqlBulkCopy,如果数据表包含大量行,这将是一个更快的选择。
SqlBulkCopy
让您可以使用来自其他源的数据有效地批量加载 SQL Server 表。
采用INSERT INTO...SELECT
INSERT INTO InvitationData (Col1, Col2, ColN)
SELECT Col1, Col2, ColN
FROM DT2
它所做的是选择所有记录(或指定记录)并将其插入到另一个表中。