C#批量更新sql实例
本文实例讲述了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#程序设计有所帮助。