c#使用datasetdatatable更新数据库的三种实现方法

人生不断学习      2022-02-08     374

关键词:

本文以实例形式讲述了使用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!

希望本文所述对大家的C#数据库程序设计有所帮助。

转自http://www.jb51.net/article/54418.htm

C# 数据库未更新使用数据集

】C#数据库未更新使用数据集【英文标题】:C#DatabasenotupdatedUsingdataset【发布时间】:2017-07-2413:14:29【问题描述】:我正在尝试获取数据集中的数据并插入10个表。但无法在数据库中插入数据。我正在使用以下代码SqlCommandcmdData=new... 查看详情

在 C# 中使用 SqlDataAdapter 更新数据库

】在C#中使用SqlDataAdapter更新数据库【英文标题】:updatedatabaseusingSqlDataAdapterinC#【发布时间】:2015-09-2011:33:30【问题描述】:我有以下代码可以在单击按钮时更新我的​​数据库表,但它不起作用。protectedvoidButton_Click(objectsender,E... 查看详情

使用 C# 更新 mySQL 表

...,发现的每个解决方案都会产生相同的错误。我有一个与数据库的开放连接,并且对数据库的更新查询已正确写入。到目前为止我想出的代码是:publicintexecuteUpd 查看详情

使用ajax c#自动刷新带有更新数据的Gridview?

】使用ajaxc#自动刷新带有更新数据的Gridview?【英文标题】:AutorefreshGridviewwithupdateddatausingajaxc#?【发布时间】:2017-11-2811:06:58【问题描述】:我正在尝试使用c#中的ajax使用更新后的数据自动更新我的gridview。我尝试制作一个ajax帖... 查看详情

使用 Access 数据库在 C# 中更新

】使用Access数据库在C#中更新【英文标题】:UpdateinC#usingAccessdatabase【发布时间】:2018-06-0322:21:12【问题描述】:我一直在尝试在DataGridView中进行更新,但它一直返回这个没有为一个或多个必需参数指定值这是我的代码privatevoidbtn... 查看详情

使用来自另一个表单的数据更新 datagridview (C#)

】使用来自另一个表单的数据更新datagridview(C#)【英文标题】:Updatedatagridviewwithdatafromanotherform(C#)【发布时间】:2015-10-0109:40:14【问题描述】:我在尝试找出如何在C#中更新datagridview时遇到问题。我有两个表单(Form1:使用datagridvi... 查看详情

如何使用 Datagridview 绑定源 C# 更新 SQL Server 数据库

】如何使用Datagridview绑定源C#更新SQLServer数据库【英文标题】:HowtoupdateSQLServerdatabaseusingDatagridviewbindingsourceC#【发布时间】:2015-01-1219:30:33【问题描述】:我正在用C#编写一个Winforms应用程序,它允许用户使用datagridview编辑和更新... 查看详情

c#使用listview更新数据出现闪烁解决办法

C#使用ListView更新数据出现闪烁解决办法在使用vs自动控件ListView控件时候,更新里面的部分代码时候出现闪烁的情况如图: 解决以后: 解决办法使用双缓冲:添加新类继承ListView对其重写1publicclassDoubleBufferListView:ListView2{3... 查看详情

使用 c# 更新或刷新控件

...作了一个winforms项目,让我可以使用SQLite搜索并添加到SQL数据库中。一种形式具有包含与疾病相关的症状或种类的TreeView和CheckedBoxList。这些控件以编程方式填充它们自己的公共非静态函数。另一种形式让我编辑数据库,特别是添... 查看详情

C# 使用数据库值更新组合框

】C#使用数据库值更新组合框【英文标题】:C#updatecomboboxwithDatabasevalues【发布时间】:2020-08-2003:58:09【问题描述】:您好,我有一个包含驱动程序的数据库和一个包含驱动程序的组合框。但是当我使用添加驱动程序按钮添加新驱... 查看详情

如何使用 MS Access 数据库在 C# 中插入或更新表

】如何使用MSAccess数据库在C#中插入或更新表【英文标题】:HowtoInsertorUpdatetableinC#withMSAccessDatabase【发布时间】:2014-10-2517:39:05【问题描述】:我使用的是SQLServer数据库,然后我将SQL数据库导出到MSAccess并在C#项目中使用该数据库... 查看详情

使用 c# 将数据更新到 Excel 工作表中

】使用c#将数据更新到Excel工作表中【英文标题】:UpdatingdataintoaExcelsheetusingc#【发布时间】:2014-01-1309:29:00【问题描述】:我正在尝试使用OLEDB连接更新格式为“xlsx”的Excel工作表中的一些数据,但我无法确定连接的建立。这是... 查看详情

如何使用 C# 在 Access 中创建、更新、删除数据?

】如何使用C#在Access中创建、更新、删除数据?【英文标题】:Howtocreate,update,deletedatainAccessusingC#?【发布时间】:2011-04-0813:40:13【问题描述】:我正在使用MicrosoftVisualC#2008ExpressEdition创建这个项目。我想使用单选按钮插入数据如... 查看详情

使用 C# 使用 CSV 文件填充 DataGridView,并使用结果更新 Access 数据库

】使用C#使用CSV文件填充DataGridView,并使用结果更新Access数据库【英文标题】:UsingC#topopulateaDataGridViewwithCSVfile,andupdateAccessdatabasewithresults【发布时间】:2012-11-2619:33:42【问题描述】:我有一个与Access数据库(accdb)交互的C#Windows窗... 查看详情

使用 C# 在 Zoho 上更新记录

...间】:2021-09-2509:42:31【问题描述】:我正在尝试更新Zoho数据库中的记录,但似乎没有任何在线C#代码可供我用来帮助查找我的问题。我的代码是:WebRequestrequest=WebRequest.Create("https://creator.zoho.com/api/v2/[groupname]/[appn 查看详情

使用 C# 在 oracle 数据库中更新多行的最佳方法

】使用C#在oracle数据库中更新多行的最佳方法【英文标题】:BestwaytoUPDATEmultiplerowsinoracledatabaseusingC#【发布时间】:2011-09-1420:31:36【问题描述】:我有一个可变的ID列表。我想更新Oracle数据库中每个ID的“状态”列。我已经搜索并... 查看详情

由于使用自动增量添加到表中,如何使用更新的数据刷新 C# DataTable?

...发布时间】:2015-03-2321:40:52【问题描述】:将数据推送到数据库后,如何用新更新的数据刷新数据表?我有一个由数据表/sqlbulkcopy组合填充的自动递增表。我需要在自动增量中生成 查看详情

C# - 使用 XML 文件中的数据更新 SQL 表

】C#-使用XML文件中的数据更新SQL表【英文标题】:C#-UpdateSQLtablewithdatafromXMLfile【发布时间】:2020-07-0700:57:10【问题描述】:我正在尝试使用C#从XML文件中读取数据,并更新我的SQL表。但什么也没有发生。我的XML看起来像这样<Use... 查看详情