批量更新数据(BatchUpdate)
批量更新数据(BatchUpdate)
/// <summary> /// 批量更新数据,注意:如果有timestamp列,要移除 /// </summary> /// <param name="sourceTable">源数据</param> /// <param name="targetTableName">目标table</param> /// <param name="primaryKeyName">主键,根据主键来更新数据,不是自增长</param> /// <param name="identity">自增长列</param> /// <param name="columnsName">列名</param> /// <param name="limitWhere">条件</param> /// <param name="batchNum">批量更新的数量</param> /// <returns></returns> public Boolean BatchUpdate(DataTable sourceTable, string targetTableName, string primaryKeyName, string identity, string[] columnsName, string limitWhere, int batchNum) { if (string.IsNullOrEmpty(targetTableName)) return false; if (string.IsNullOrEmpty(primaryKeyName)) return false; if (columnsName == null || columnsName.Length <= 0) return false;
DataSet ds = new DataSet();
ds.Tables.Add(sourceTable);
ds.Tables[].TableName = targetTableName; using (SqlConnection conn = new SqlConnection(strConn))
{
conn.Open(); using (SqlTransaction transaction = conn.BeginTransaction(IsolationLevel.ReadCommitted))//使用加强读写锁事务,避免脏读
{ try
{ foreach (DataRow row in ds.Tables[].Rows)
{
row.AcceptChanges();
row.SetModified();//所有行设置为可修改
} string cols = string.Join(",", columnsName);
cols = "[" + cols.Replace(",", "],[") + "]";
SqlCommand cmd = new SqlCommand(string.Format("SELECT {2} FROM {0} WHERE {1}", targetTableName, limitWhere, cols), conn);
cmd.Transaction = transaction;
SqlDataAdapter adapter = new SqlDataAdapter(cmd);
SqlCommandBuilder sqlCmdBuilder = new SqlCommandBuilder(adapter);
adapter.AcceptChangesDuringFill = false;
adapter.Fill(ds); string updateSQL = string.Empty;
SqlParameter[] paras = new SqlParameter[columnsName.Length]; for (int i = ; i < columnsName.Length; i++)
{ //去除自增长ID ,根据可控的自增Id进行更新 if (columnsName[i] != primaryKeyName && columnsName[i] != identity)
{
updateSQL += ("[" + columnsName[i] + "]" + "=@" + columnsName[i] + ",");
} if (sourceTable.Columns[i].DataType.Name == "Int32")
{
paras[i] = new SqlParameter("@" + columnsName[i], SqlDbType.Int, , columnsName[i]);
} else if (sourceTable.Columns[i].DataType.Name == "DateTime")
{
paras[i] = new SqlParameter("@" + columnsName[i], SqlDbType.DateTime, , columnsName[i]);
} else if (sourceTable.Columns[i].DataType.Name == "Double")
{
paras[i] = new SqlParameter("@" + columnsName[i], SqlDbType.Decimal, , columnsName[i]);
} else
{
paras[i] = new SqlParameter("@" + columnsName[i], SqlDbType.NVarChar, -, columnsName[i]);//-1表示大于4000的长度
}
} if (!string.IsNullOrEmpty(updateSQL))
{
updateSQL = updateSQL.Trim(',');
} string limitSql = ("[" + primaryKeyName + "]" + "=@" + primaryKeyName);
SqlCommand updateCmd = new SqlCommand(string.Format("UPDATE {0} SET {1} WHERE {2}", targetTableName, updateSQL, limitSql)); //设置不修改源Table
updateCmd.UpdatedRowSource = UpdateRowSource.None;
adapter.UpdateCommand = updateCmd;
adapter.UpdateCommand.Parameters.AddRange(paras);
updateCmd.Transaction = transaction;
adapter.UpdateCommand.CommandTimeout = ;//超时时间
adapter.UpdateBatchSize = batchNum;
adapter.Update(ds, targetTableName);
ds.AcceptChanges();
transaction.Commit(); return true;
} catch (Exception ex)
{
transaction.Rollback(); return false; throw ex;
} finally
{
conn.Close();
conn.Dispose();
}
}
}
}
批量更新数据(BatchUpdate)的更多相关文章
- mybatis学习之路----批量更新数据两种方法效率对比
原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...
- 批量更新数据小心SQL触发器的陷阱
批量更新数据时候,Inserted和Deleted临时表也是批量的,但触发器只会调用执行一次!两个概念千万不要弄混淆! 错误的理解:例如:创建在A表上创建了一个Update触发器,里面写的是Updat ...
- Neo4j 第五篇:批量更新数据
相比图形数据的查询,Neo4j更新图形数据的速度较慢,通常情况下,Neo4j更新数据的工作流程是:每次数据更新都会执行一次数据库连接,打开一个事务,在事务中更新数据.当数据量非常大时,这种做法非常耗时 ...
- SQL批量更新数据
SQL批量更新数据 step1:导入Excel数据, 具体见百度.注意点:一列中含有float型数据和文本数据的时候,导入要将Excel中的表格属性改成文本,或在数字项目前加个单引号. step2 ...
- mysql 常用命令,连接数据库,查看建表语句,批量导入数据,批量更新数据,连接查询
1. 1)MySQL 连接本地数据库,从cmd中进入mysql命令编辑器: root root分别为用户名和密码 mysql -uroot -proot 2)MySQL 连接本地数据库,用户名为“ro ...
- mysql下的将多个字段名的值复制到另一个字段名中(批量更新数据)字符串拼接cancat实战例子
mysql下的将多个字段名的值复制到另一个字段名中(批量更新数据)mysql字符串拼接cancat实战例子: mysql update set 多个字段相加,如果是数字相加可以直接用+号(注:hund ...
- FreeSql (十四)批量更新数据
FreeSql支持丰富的更新数据方法,支持单条或批量更新,在特定的数据库执行还可以返回更新后的记录值. var connstr = "Data Source=127.0.0.1;Port=3 ...
- SqlServer 利用游标批量更新数据
SqlServer 利用游标批量更新数据 Intro 游标在有时候会很有用,在更新一部分不多的数据时,可以很方便的更新数据,不需要再写一个小工具来做了,直接写 SQL 就可以了 Sample 下面来看 ...
- MongoDB的批量查询条件进行批量更新数据
今天遇到这样一个场景:在Java中批量更新MongoDB数据,不过每次更新的条件有不一样,那如何有效地进行更新操作呢? 刚开始的时候,我是想到循环批量更新操作,即每一种查询条件进行一次批量更新过程,这 ...
随机推荐
- 2018/8/26学习Mysql笔记
SELECT * FROM product; #.基本增删改查 #新增 #需求:添加一条数据到产品表 产品名称为苹果手机 卖价为5000 ); #删除 #需求:删除产品表中id=20的数据 ; #需求 ...
- Ceph的正确玩法之Ceph纠删码理论与实践
http://blog.itpub.net/31545808/viewspace-2637083/ 注意空格,有的命令少空格 随着云计算业务的快速发展,国内外云计算企业的专利之争也愈发激烈.在云计算这 ...
- atexit函数学习
函数名: atexit 头文件:#include<stdlib.h> 功 能: 注册终止函数(即main执行结束后调用的函数) 用 法: void atexit(void (*func)( ...
- paper 139:qt超强绘图控件qwt - 安装及配置
qwt是一个基于LGPL版权协议的开源项目, 可生成各种统计图.它为具有技术专业背景的程序提供GUI组件和一组实用类,其目标是以基于2D方式的窗体部件来显示数据, 数据源以数值,数组或一组浮点数等方式 ...
- 前端每日实战:77# 视频演示如何用纯 CSS 创作旗帜飘扬的动画
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/qydvBm 可交互视频 此视频是可 ...
- win10配置 samba
一.先確認Linux中smb正確配置可以使用命令smbclient -L //localhost/ 二.win10配置1.打開win10對smb1.0/cifs檔共用支援2.本地群組原則編輯,修改如下 ...
- 学号 20175223 《Java程序设计》第10周学习总结
目录 教材学习内容总结 代码调试中的问题和解决过程 1. XAMPP无法启用 MySQL 程序. 2. Ubuntu 无法下载或更新. [代码托管] 学习进度条 参考资料 目录 教材学习内容总结 第十 ...
- 2019 ICPC Asia Nanchang Regional E Eating Plan 离散化+前缀和
题意: 给你n个盘子,这n个盘子里面分别装着1!到n!重量的食物,对于每一个询问k,找出一个最短的区间,使得区间和 mod 998857459 大于或等于k 盘子数量 n<=1e5 询问次数 m ...
- Oracle10gr2 开机自启动脚本
目录 目录 软件环境 Oracle服务启动停止重启脚本 软件环境 操作系统 RHEL6.1 软件 Oracle10gr2 Oracle服务启动.停止.重启脚本 su - oracle cd /u01/ ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 (B L )
B. Light bulbs 思路:差分 + 离散化, 好不容易懂了差分却没想到离散化,还是要罗老板出马..... AC代码: #include<bits/stdc++.h> using ...