SqlCommandBuilder类如何批量更新excel或者CSV数据
发表于:2024-11-12 作者:千家信息网编辑
千家信息网最后更新 2024年11月12日,这篇文章给大家分享的是有关SqlCommandBuilder类如何批量更新excel或者CSV数据的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。当你批量操作数据的时候,常常
千家信息网最后更新 2024年11月12日SqlCommandBuilder类如何批量更新excel或者CSV数据
这篇文章给大家分享的是有关SqlCommandBuilder类如何批量更新excel或者CSV数据的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
当你批量操作数据的时候,常常会使用到update table1 from table2的这种方式,这种方式是最简洁的。
但当你从excel或者CSV文件更新海量数据时,再使用这种方法,那性能是不是好?字符串拼接又何其之多,大数据是不是需要分组更新?
我不想去检测各种方法的速度,因为我个人比较认可以下方式,欢迎大家批评与指正。
我需要使用到的类主要是SqlCommandBuilder。
/// 准备更新的DataTable新数据 /// 对应要更新的数据库表名 /// 对应要更新的数据库表的主键名 /// 对应要更新的列的列名集合 /// 需要在SQL的WHERE条件中限定的条件字符串,可为空。 /// 每次往返处理的行数 ///返回更新的行数 public static int Update(DataTable table, string TableName, string primaryKeyName, string[] columnsName, string limitWhere,int onceUpdateNumber) { if (string.IsNullOrEmpty(TableName)) return 0; if (string.IsNullOrEmpty(primaryKeyName)) return 0; if (columnsName == null || columnsName.Length <= 0) return 0; DataSet ds = new DataSet(); ds.Tables.Add(table); int result = 0; using (SqlConnection sqlconn = new SqlConnection(SqlHelper.ConnString)) { sqlconn.Open(); //使用加强读写锁事务 SqlTransaction tran = sqlconn.BeginTransaction(IsolationLevel.ReadCommitted); try { foreach (DataRow dr in ds.Tables[0].Rows) { //所有行设为修改状态 dr.SetModified(); } //为Adapter定位目标表 SqlCommand cmd = new SqlCommand(string.Format("select * from {0} where {1}", TableName,limitWhere), sqlconn, tran); SqlDataAdapter da = new SqlDataAdapter(cmd); SqlCommandBuilder sqlCmdBuilder = new SqlCommandBuilder(da); da.AcceptChangesDuringUpdate = false; string columnsUpdateSql = ""; SqlParameter[] paras = new SqlParameter[columnsName.Length]; //需要更新的列设置参数是,参数名为"@+列名" for (int i = 0; i < columnsName.Length; i++) { //此处拼接要更新的列名及其参数值 columnsUpdateSql += ("[" + columnsName[i] + "]" + "=@" + columnsName[i] + ","); paras[i] = new SqlParameter("@" + columnsName[i], columnsName[i]); } if (!string.IsNullOrEmpty(columnsUpdateSql)) { //此处去掉拼接处最后一个"," columnsUpdateSql = columnsUpdateSql.Remove(columnsUpdateSql.Length - 1); } //此处生成where条件语句 string limitSql = ("[" + primaryKeyName + "]" + "=@" + primaryKeyName); SqlCommand updateCmd = new SqlCommand(string.Format(" UPDATE [{0}] SET {1} WHERE {2} ", TableName, columnsUpdateSql, limitSql)); //不修改源DataTable updateCmd.UpdatedRowSource = UpdateRowSource.None; da.UpdateCommand = updateCmd; da.UpdateCommand.Parameters.AddRange(paras); da.UpdateCommand.Parameters.Add("@" + primaryKeyName, primaryKeyName); //每次往返处理的行数 da.UpdateBatchSize = onceUpdateNumber; result = da.Update(ds,TableName); ds.AcceptChanges(); tran.Commit(); } catch { tran.Rollback(); } finally { sqlconn.Dispose(); sqlconn.Close(); } } return result; }
注: 此方法调用时要传入的参数,包括主键名和列名都应与数据库实际的名称相对应。
你可以不传入限定的where条件,如果传入,只需传入:Name="chamy" or Name="jundy",不需加入"where"等字符,不可以在此处传入主键的限定,你只需要在主键名这个参数上传入名称即可。
感谢各位的阅读!关于"SqlCommandBuilder类如何批量更新excel或者CSV数据"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
更新
数据
参数
条件
字符
数据库
方式
内容
名称
字符串
方法
更多
篇文章
处理
不错
实用
简洁
个人
事务
只需
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
怎么更新多表查询的数据库表
服务器虚拟化安装
北京软件开发公司前十名
16亿数据库说名
联想服务器读秒启动不起来
绝地求生2022服务器维护
服务器win10
2021金盾信安杯网络安全大赛
什么叫域名服务器
广东高中英语考试软件开发商
软件开发人员国家资质认证
枣庄软件开发初级教材哪家好
大通网络技术
软件开发人员的趋势
汽车交易的互联网科技服务
有什么好玩的服务器
知网中数据库进入
数据库安全管理试题
dell塔式服务器u盘装系统
网络安全作业平台登录
关系型数据库有哪些缺点
手机软件开发公司经营范围
我的世界服务器免费端
怎么获得服务器管理员密码
丰台区正规软件开发操作
软件开发闭门造车 自娱自乐
扬州通用软件开发咨询报价
苹果手机连接服务器出错什么情况
嘉定区运营软件开发制造价格
最快的服务器租用