1.批量新增,采用高效的SqlBulkCopy
using (SqlBulkCopy sbc = new SqlBulkCopy(db.ConnectionString))
{
sbc.DestinationTableName = dataTable.TableName;
sbc.BatchSize = dataTable.Rows.Count;
sbc.BulkCopyTimeout = 300;
sbc.WriteToServer(dataTable);
}
2.批量新增、修改、删除,采用SqlDataAdapter,如下代码段可根据DataTable.RowState (关于RowState参考我的另一篇文章介绍)状态进行新增及删除,
但是发现 批量修改不好使,具体看第3点
SqlConnection conn = new SqlConnection(strConnection));
SqlCommand myCommand = new SqlCommand("select * from "+strTblName+" where 1=2"),(SqlConnection) conn);
SqlDataAdapter myAdapter = new SqlDataAdapter(myCommand );
SqlCommandBuilder myCommandBuild