Datatable更新数据库
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Datatable更新数据库相关的知识,希望对你有一定的参考价值。
有一个datatable变量dt里存的是某表下某字段的所有值,我要把这个dt更新到这个表,该怎么处理。(注意不能一条一条读出来,一条一条insert进去)
参考技术A 可以用SqlBulkCopy批量导入,命名空间:System.Data.SqlClient;部分代码参考:
SqlConnection sqlConn = new SqlConnection(strConn);
sqlConn.Open();
SqlTransaction tran = sqlConn.BeginTransaction();
using (SqlBulkCopy oBC= new SqlBulkCopy (sqlConn,SqlBulkCopyOptions.Default, tran))
oBC.ColumnMappings.Add("fld1", "fld1"); //第一个参数为源数据(datatable变量)列的字段,第二个参数为目标数据(数据库表)列的字段
oBC.ColumnMappings.Add("fld2", "fld2");
oBC.ColumnMappings.Add("fld3", "fld3");
oBC.DestinationTableName = "TaleName"; //TaleName为数据库中的表名
oBC.WriteToServer(oDataTable);//oDataTable为你的datatable实例
tran.Commit();
sqlConn.Close();
参考技术B SqlCommandBuilder cmd = new System.Data.SqlClient.SqlCommandBuilder(datp);
SqlDataAdapter datp = new SqlDataAdapter("select * from tb","server=.;database=test;uid=sa;pwd=sa");
datp.Update(dtable);本回答被提问者采纳 参考技术C sqlserver 有个批量更新 。
update table1
set 字段=值
from table2
where table1.key = table2.key
条件还能自己加。可以更新一批符合的数据 参考技术D Datatable更新数据库
SqlDataAdapter adapter = new SqlDataAdapter(strSql, strConn);
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
DataSet ds = new DataSet();
adapter.Fill(ds, "Titles");
//插入记录
DataTable table = ds.Tables["Titles"];
DataRow row = table.NewRow();
row["Title_id"] = "JP1001";
row["title"] = "programming Microsoft .NET";
row["price"] = 59.99m;
row["ytd_sales"] = 100000;
row["type"] = "business";
row["pubdate"] = new DateTime(2002, 5, 1);
table.Rows.Add(row);
//更新数据库
adapter.Update(table); 第5个回答 2011-02-23 pdate 一下就OK咯
C#使用DataSet Datatable更新数据库的三种实现方法
(http://www.jb51.net/article/54418.htm)
这篇文章主要介绍了C#从DataTable获取数据的方法,涉及C#操作DataTable的相关技巧,需要的朋友可以参考下
本文以实例形式讲述了使用DataSet Datatable更新数据库的三种实现方法,包括CommandBuilder 方法、DataAdapter 更新数据源以及使用sql语句更新。分享给大家供大家参考之用。具体方法如下:
一、自动生成命令的条件 CommandBuilder 方法
a)动态指定 SelectCommand 属性
b)利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand、InsertCommand 和 UpdateCommand。
c)为了返回构造 INSERT、UPDATE 和 DELETE 。SQL CommandBuilder 必须执行 SelectCommand。
即:必须额外经历一次到数据源的行程,这可能会降低性能。这也是自动生成命令的缺点。
d)SelectCommand 还必须返回至少一个主键或唯一列.
当CommandBuilder和DataAdapter关联时,就会自动生成DeleteCommand、InsertCommand 和 UpdateCommand中为空的命令。即不空的不生成。
e)必须是一个表,SELECT的不能是多个表的联合。
动生成命令的规则:
在数据源处为表中所有 RowState 为 Added 的行插入一行(不包括标识、表达式或时间戳等列)。
为 Modified 的行更新行(列值匹配行的主键列值) 。
Deleted 的行删除行(列值匹配行的主键列值).这就是为什么要求条件c.d
注意:
a)因为从SELECT数据到UPDATE数据,中间这段时间有可能别的用户已经对数据进行了修改。自动生成命令这种UPDATE只对在行包含所有原始值并且尚未从数据源中删除时更新。
b)自动命令生成逻辑为独立表生成 INSERT、UPDATE 或 DELETE 语句,而不考虑与数据源中其他表的任何关系。因此,当调用 Update 来为参与数据库中外键约束的列提交更改时,可能会失败。若要避免这一异常,请不要使用 CommandBuilder 来更新参与外键约束的列,而应显式地指定用于执行该操作的语句。
下面是自动生成命令的例子
- // Assumes that connection is a valid SqlConnection
- object.SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM dbo.Customers", connection);
- SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
- builder.QuotePrefix = "[";builder.QuoteSuffix = "]";
- DataSet custDS = new DataSet(); connection.Open();
- adapter.Fill(custDS, "Customers");
- // Code to modify data in the DataSet here.
- // Without the SqlCommandBuilder, this line would fail.
- adapter.Update(custDS, "Customers");
- connection.Close();
?
二、使用 DataAdapter 更新数据源
需要注意:
a)如果 SelectCommand 返回 OUTER JOIN 的结果,则 DataAdapter 不会为生成的 DataTable 设置 PrimaryKey 值。您必须自己定义PrimaryKey 以确保正确解析重复行.
b)如果对 DataSet、DataTable 或 DataRow 调用 AcceptChanges,则将使 DataRow 的所有 Original 值都将被重写为该 DataRow 的 Current 值。如果已修改将该行标识为唯一行的字段值,那么当调用 AcceptChanges 后,Original 值将不再匹配数据源中的值。
看看下面例子:
- // Assumes connection is a valid SqlConnection.
- ???????SqlDataAdapter dataAdpater = new SqlDataAdapter("SELECT CategoryID, CategoryName FROM Categories", connection);
- ???????dataAdpater.UpdateCommand = new SqlCommand("UPDATE Categories SET CategoryName = @CategoryName " +"WHERE CategoryID = @CategoryID" , connection);
- ???????dataAdpater.UpdateCommand.Parameters.Add("@CategoryName", SqlDbType.NVarChar, 15, "CategoryName");
- ???????SqlParameter parameter = dataAdpater.UpdateCommand.Parameters.Add("@CategoryID", SqlDbType.Int);
- ???????parameter.SourceColumn = "CategoryID";
- ???????parameter.SourceVersion = DataRowVersion.Original;
- ???????DataSet dataSet = new DataSet();dataAdpater.Fill(dataSet, "Categories");
- ???????DataRow row = dataSet.Tables["Categories"].Rows[0];
- ???????row ["CategoryName"] = "New Category"; dataAdpater.Update(dataSet, "Categories");
?
插入、更新和删除的排序
在许多情况下,以何种顺序向数据源发送通过 DataSet 作出的更改是相当重要的。
例如,如果已更新现有行的主键值并且添加了具有新主键值的新行,则务必要在处理插入之前处理更新。
可以使用 DataTable 的 Select 方法来返回仅引用具有特定 RowState 的 DataRow 数组。然后可以将返回的 DataRow 数组传递到 DataAdapter 的 Update 方法来处理已修改的行。通过指定要更新的行的子集,可以控制处理插入、更新和删除的顺序。
示例如下:
- DataTable table = dataSet.Tables["Customers"];
- // First process deletes.
- adapter.Update(table.Select(null, null, DataViewRowState.Deleted));
- // Next process updates.
- adapter.Update(table.Select(null, null, DataViewRowState.ModifiedCurrent));
- // Finally, process inserts.
- adapter.Update(table.Select(null, null, DataViewRowState.Added));
?
三、使用sql语句更新
例如:
- cmd = new OleDbCommand(string.Format(@"insert into worker(workerid,workername,password,phoneno) values (‘{0}‘,‘{1}‘,‘{2}‘,‘{3}‘) ", textBox1.Text, textBox2.Text, textBox3.Text, textBox4.Text),oc);
- oc.Open();
- try
- {
- int i = cmd.ExecuteNonQuery();
- }
- catch (Exception ex)
- {
- }
性能的优劣及使用的情形,还未完全明白。
一般的,绑定bindingsource,用datatable绑定bindingsource (实质上绑定的是datatable。defaultview,同时可用到dataview的筛选功能,但是在筛选完后,filter要重置为null,否则出现的一直是经过筛选的数据)
其他:
使用builder 的作用:
?
- OleDbCommandBuilder cb = new OleDbCommandBuilder(da);
这个主要是为了让C#自动为OleDbDataAdapter da生成相对应的DeleteCommand,UpdateCommand!
?
?
以上是关于Datatable更新数据库的主要内容,如果未能解决你的问题,请参考以下文章
更改 DataTable 中的 DataColumnCollection 后更新数据库
C#使用DataSet Datatable更新数据库的三种实现方法