C# winform DataTable 批量数据处理 增、删、改 .

1.批量新增,采用高效的SqlBulkCopy

 SqlBulkCopy DTS = new System.Data.SqlClient.SqlBulkCopy(con);
                DTS.NotifyAfter = 1;
                DTS.DestinationTableName = datatable.name;
                DTS.BulkCopyTimeout = 60000000;
                DTS.WriteToServer(datatable);
                succ = dtSource.Rows.Count.ToString();

2.SqlCommandBuilder    update 批量修改的问题

 1               DataSet ds = new DataSet();
 2             ds.Tables.Add(table);
 3             string _tableName = table.TableName;
 4             int result = 0;
 5            using (SqlConnection sqlconn = new SqlConnection(db.ConnectionString))
 6             {
 7                 sqlconn.Open();
 8
 9                 //使用加强读写锁事务
10                SqlTransaction tran = sqlconn.BeginTransaction(IsolationLevel.ReadCommitted);
11                 try
12                 {
13
14                     ds.Tables[0].AcceptChanges();
15                     foreach (DataRow dr in ds.Tables[0].Rows)
16                     {
17                        //所有行设为修改状态
18                         dr.SetModified();
19                    }
20                    //为Adapter定位目标表
21
22                     SqlCommand cmd = new SqlCommand(string.Format("select * from {0} where {1}", _tableName, " 1=2"), sqlconn, tran);
23                    SqlDataAdapter da = new SqlDataAdapter(cmd);
24                    SqlCommandBuilder sqlCmdBuilder = new SqlCommandBuilder(da);
25                    sqlCmdBuilder.ConflictOption = ConflictOption.OverwriteChanges;
26                     da.AcceptChangesDuringUpdate = false;
27                    string columnsUpdateSql = "";
28                    SqlParameter[] paras = new SqlParameter[table.Columns.Count];
29                    int parasIndex = 0;
30                     //需要更新的列设置参数是,参数名为"@+列名"
31                     for (int i = 0; i < table.Columns.Count; i++)
32                    {
33                        //此处拼接要更新的列名及其参数值
34                         columnsUpdateSql += ("[" + table.Columns[i].ColumnName + "]" + "[email protected]" + table.Columns[i].ColumnName + ",");
35                         if (table.Columns[i].DataType.Name == "DateTime")
36                        {
37                             paras[i] = new SqlParameter("@" + table.Columns[i].ColumnName, SqlDbType.DateTime, 23, table.Columns[i].ColumnName);
38                         }
39                        else if (table.Columns[i].DataType.Name == "Int64")
40                        {
41                             paras[i] = new SqlParameter("@" + table.Columns[i].ColumnName, SqlDbType.NVarChar, 19, table.Columns[i].ColumnName);
42                        }
43                        else
44                        {
45                             paras[i] = new SqlParameter("@" + table.Columns[i].ColumnName, SqlDbType.NVarChar, 2000, table.Columns[i].ColumnName);
46                        }
47                     }
48                    if (!string.IsNullOrEmpty(columnsUpdateSql))
49                     {
50                        //此处去掉拼接处最后一个","
51                        columnsUpdateSql = columnsUpdateSql.Remove(columnsUpdateSql.Length - 1);
52                     }
53                     //此处生成where条件语句
54                    string limitSql = ("[" + table.Columns[0].ColumnName + "]" + "[email protected]" + table.Columns[0].ColumnName);
55                   SqlCommand updateCmd = new SqlCommand(string.Format(" UPDATE [{0}] SET {1} WHERE {2} ", _tableName, columnsUpdateSql, limitSql));
56                     //不修改源DataTable
57                    updateCmd.UpdatedRowSource = UpdateRowSource.None;
58                    da.UpdateCommand = updateCmd;
59                     da.UpdateCommand.Parameters.AddRange(paras);
60                     //da.UpdateCommand.Parameters.Add("@" + table.Columns[0].ColumnName, table.Columns[0].ColumnName);
61                     //每次往返处理的行数
62                    da.UpdateBatchSize = table.Rows.Count;
63                     result = da.Update(ds, _tableName);
64                     ds.AcceptChanges();
65                     tran.Commit();
66
67                 }
68                catch(Exception ex)
69                 {
70                    tran.Rollback();
71                    throw ex;
72                }
73                 finally
74                {
75                     sqlconn.Dispose();
76                     sqlconn.Close();
77                }
78           }  

装载 http://blog.csdn.net/liudong8510/article/details/17000997

时间: 2024-10-11 16:05:16

C# winform DataTable 批量数据处理 增、删、改 .的相关文章

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform)让用户方便的操作数据库中的数据. 什么是ADO.NET 是一组库类,System.Data. Ado.net组成 Connection:用来连接数据库 Command:用来执行SQL语句 DataReader:只读.只进的结果集,一条一条读取数据(SteamReader.XmlReader) Da

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

SQL 增/删/改/查 (总结)

1.增 INSERT  INTO  表名  VALUES (" "," ") ; INSERT INTO 表名(字段)  VALUES(" "); 2. 删 DELETE   FROM 表名  WHERE  ... 3.改 UPDATE  表名 SET   ... WHERE  ... 4.查 SELECT × FROM  表名 ORDER BY ...

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

2016/05/05 smarty 增 删 改

共  八个页面 ①login.php 1 <?php 2 include("init.inc.php"); 3 4 $smarty->display("login.html"); 5 ?> ②login.html  显示模板  在templates模板文件夹中 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset=&q