批量更新数据(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)的更多相关文章

  1. mybatis学习之路----批量更新数据两种方法效率对比

    原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...

  2. 批量更新数据小心SQL触发器的陷阱

    批量更新数据时候,Inserted和Deleted临时表也是批量的,但触发器只会调用执行一次!两个概念千万不要弄混淆! 错误的理解:例如:创建在A表上创建了一个Update触发器,里面写的是Updat ...

  3. Neo4j 第五篇:批量更新数据

    相比图形数据的查询,Neo4j更新图形数据的速度较慢,通常情况下,Neo4j更新数据的工作流程是:每次数据更新都会执行一次数据库连接,打开一个事务,在事务中更新数据.当数据量非常大时,这种做法非常耗时 ...

  4. SQL批量更新数据

    SQL批量更新数据 step1:导入Excel数据, 具体见百度.注意点:一列中含有float型数据和文本数据的时候,导入要将Excel中的表格属性改成文本,或在数字项目前加个单引号.   step2 ...

  5. mysql 常用命令,连接数据库,查看建表语句,批量导入数据,批量更新数据,连接查询

    1. 1)MySQL 连接本地数据库,从cmd中进入mysql命令编辑器: root root分别为用户名和密码 mysql -uroot -proot 2)MySQL 连接本地数据库,用户名为“ro ...

  6. mysql下的将多个字段名的值复制到另一个字段名中(批量更新数据)字符串拼接cancat实战例子

    mysql下的将多个字段名的值复制到另一个字段名中(批量更新数据)mysql字符串拼接cancat实战例子: mysql update set 多个字段相加,如果是数字相加可以直接用+号(注:hund ...

  7. FreeSql (十四)批量更新数据

    FreeSql支持丰富的更新数据方法,支持单条或批量更新,在特定的数据库执行还可以返回更新后的记录值. var connstr = "Data Source=127.0.0.1;Port=3 ...

  8. SqlServer 利用游标批量更新数据

    SqlServer 利用游标批量更新数据 Intro 游标在有时候会很有用,在更新一部分不多的数据时,可以很方便的更新数据,不需要再写一个小工具来做了,直接写 SQL 就可以了 Sample 下面来看 ...

  9. MongoDB的批量查询条件进行批量更新数据

    今天遇到这样一个场景:在Java中批量更新MongoDB数据,不过每次更新的条件有不一样,那如何有效地进行更新操作呢? 刚开始的时候,我是想到循环批量更新操作,即每一种查询条件进行一次批量更新过程,这 ...

随机推荐

  1. MySQL-常用引擎

    来自:https://www.cnblogs.com/xujishou/p/6343431.html :https://www.cnblogs.com/laowenBlog/p/8405614.htm ...

  2. 推荐五个java基础学习网站,小白必备

    不知道去哪找java基础资料?推荐几个学习网站,小白必备 Java经过20多年的发展,仍然是世界上最受欢迎的编程语言之一,有无限多种方法使用Java.拥有庞大的客户群.并且java应用范围很广,基本只 ...

  3. 【LeetCode 38】报数

    题目链接 [题解] 模拟题 [代码] class Solution { public: string inttostr(int x){ string temp=""; while ...

  4. layui多图上传加隐藏域

    我的情况是,通过layui上传图片调用后端,后端将图片上传后返回图片路径,上传成功后将图片在页面显示出来(避免用户网速不稳定,图片其实还没上传成功就进行下一步操作),然后同步每个图片增加隐藏域,最终表 ...

  5. WebView loadRequest请求错误"NSURLConnection finished with error - code -1022"

    执行下面代码 [self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www ...

  6. redis安装-1

    redis安装 cd /opt/tools/ #包目录 tar -xf redis-.tar.gz cd redis- make#centos7安装   make MALLOC=libc && ...

  7. Myeclipse下使用Maven搭建spring boot2.0项目

    现在需要搭建spring boot框架,并实现一个HelloWorld的项目,让程序真正运行起来. 一.在pom.xml中引入spring-boot-start-parent,spring官方的叫st ...

  8. HTML5: HTML(5) 代码规范

    ylbtech-HTML5: HTML(5) 代码规范 1.返回顶部 1. HTML(5) 代码规范 HTML 代码约定 很多 Web 开发人员对 HTML 的代码规范知之甚少. 在2000年至201 ...

  9. 使用java读取excel数据

    package excelOperation2; import java.io.File; import java.io.FileNotFoundException; import java.util ...

  10. Missing artifact net.sf.json-lib:json-lib:jar:2.4

    Missing artifact net.sf.json-lib:json-lib:jar:2.4 出现上述这种错误就是JAR没有引入进来 这时候发现是因为JDK版本的问题,所以需要在加一句 < ...