c#中怎样批量更新数据库的数据

c#中怎样批量更新数据库的数据,第1张

如果每个用户请求更改一行,那他就只能该一行就更新,这个逻辑没有错。

如果你要让他不是及时更新,可以做成队列。

SQL语句更新的速度可能是比存储过程慢一些,但是一个区区30万的小数据,对于SQL

SERVER数据库来说根本就是小菜。

换句话说,别说SQL

SERVER了,就是MYSQL这种小型数据库,对付百万级的数据都是很轻松的。。。

一般用SqlDataAdapter批量更新就行了,你可以参照下面的代码,另一个可以参考的是这个

http://clingingboy.cnblogs.com/archive/2006/04/29/389039.html

下面代码一次是5000个,具体在你那数值是多少可以测试一下

/// <summary>

/// 批量更新数据(每批次5000)

/// </summary>

/// <param name="connString">数据库链接字符串</param>

/// <param name="table"></param>

public static void Update(string connString, DataTable table)

{

SqlConnection conn = new SqlConnection(connString)

SqlCommand comm = conn.CreateCommand()

comm.CommandTimeout = _CommandTimeOut

comm.CommandType = CommandType.Text

SqlDataAdapter adapter = new SqlDataAdapter(comm)

SqlCommandBuilder commandBulider = new SqlCommandBuilder(adapter)

commandBulider.ConflictOption = ConflictOption.OverwriteChanges

try

{

conn.Open()

//设置批量更新的每次处理条数

adapter.UpdateBatchSize = 5000

adapter.SelectCommand.Transaction = conn.BeginTransaction()/////////////////开始事务

if (table.ExtendedProperties["SQL"] != null)

{

adapter.SelectCommand.CommandText = table.ExtendedProperties["SQL"].ToString()

}

adapter.Update(table)

adapter.SelectCommand.Transaction.Commit()/////提交事务

}

catch (Exception ex)

{

if (adapter.SelectCommand != null &&adapter.SelectCommand.Transaction != null)

{

adapter.SelectCommand.Transaction.Rollback()

}

throw ex

}

finally

{

conn.Close()

conn.Dispose()

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6850198.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-29
下一篇 2023-03-29

发表评论

登录后才能评论

评论列表(0条)

保存