本文实例讲述了C#批量更新sql的方法,分享给大家供大家参考。具体方法如下:
要实现批量更新Card数据,主要有以下步骤:
1、首先建立数据库连接
2、把部分数据填充到Dataset中
3、修改Dataset中数据的值
4、更新Dataset
5、循环操作,具体操作过程见下面代码:
public void BatchUpdate(List<Card> list) { using (SqlConnection conn = new SqlConnection(DbHelperSQL.connectionString)) { conn.Open(); using (SqlDataAdapter da = new SqlDataAdapter()) { da.SelectCommand = new SqlCommand("select top 100 ScanFlag,CardId from Card",conn); DataSet ds = new DataSet(); da.Fill(ds);da.UpdateCommand = new SqlCommand("update Card set ScanFlag = @ScanFlag where CardId = @CardId", conn); da.UpdateCommand.Parameters.Add("@ScanFlag", SqlDbType.Bit, 1, "ScanFlag"); da.UpdateCommand.Parameters.Add("@CardId", SqlDbType.Int, 4, "CardId"); da.UpdateCommand.UpdatedRowSource = UpdateRowSource.None; da.UpdateBatchSize = 0;
for (int i = 0; i < list.Count; i++) { for (int j = 0; j < ds.Tables[0].Rows.Count; j++, i++) { ds.Tables[0].Rows[j].BeginEdit(); ds.Tables[0].Rows[j]["ScanFlag"] = true; ds.Tables[0].Rows[j]["CardId"] = list[i].CardId; ds.Tables[0].Rows[j].EndEdit(); if (i == list.Count - 1) break; } da.Update(ds.Tables[0]); } ds.Clear(); ds.Dispose(); } } }
希望本文所述对大家的C#程序设计有所帮助。