C#使用DataSetDatatable更新数据库的三种实现方法
本文以实例形式讲述了使用DataSetDatatable更新数据库的三种实现方法,包括CommandBuilder方法、DataAdapter更新数据源以及使用sql语句更新。分享给大家供大家参考之用。具体方法如下:
一、自动生成命令的条件CommandBuilder方法
a)动态指定SelectCommand属性
b)利用CommandBuilder对象自动生成DataAdapter的DeleteCommand、InsertCommand和UpdateCommand。
c)为了返回构造INSERT、UPDATE和DELETE。SQLCommandBuilder必须执行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来更新参与外键约束的列,而应显式地指定用于执行该操作的语句。
下面是自动生成命令的例子
//AssumesthatconnectionisavalidSqlConnectionobject. SqlDataAdapteradapter=newSqlDataAdapter( "SELECT*FROMdbo.Customers",connection); SqlCommandBuilderbuilder=newSqlCommandBuilder(adapter); builder.QuotePrefix="["; builder.QuoteSuffix="]"; DataSetcustDS=newDataSet(); connection.Open(); adapter.Fill(custDS,"Customers"); //CodetomodifydataintheDataSethere. //WithouttheSqlCommandBuilder,thislinewouldfail. adapter.Update(custDS,"Customers"); connection.Close();
二、使用DataAdapter更新数据源
需要注意:
a)如果SelectCommand返回OUTERJOIN的结果,则DataAdapter不会为生成的DataTable设置PrimaryKey值。您必须自己定义PrimaryKey以确保正确解析重复行.
b)如果对DataSet、DataTable或DataRow调用AcceptChanges,则将使DataRow的所有Original值都将被重写为该DataRow的Current值。如果已修改将该行标识为唯一行的字段值,那么当调用AcceptChanges后,Original值将不再匹配数据源中的值。
看看下面例子:
//AssumesconnectionisavalidSqlConnection. SqlDataAdapterdataAdpater=newSqlDataAdapter( "SELECTCategoryID,CategoryNameFROMCategories",connection); dataAdpater.UpdateCommand=newSqlCommand( "UPDATECategoriesSETCategoryName=@CategoryName"+ "WHERECategoryID=@CategoryID",connection); dataAdpater.UpdateCommand.Parameters.Add( "@CategoryName",SqlDbType.NVarChar,15,"CategoryName"); SqlParameterparameter=dataAdpater.UpdateCommand.Parameters.Add( "@CategoryID",SqlDbType.Int); parameter.SourceColumn="CategoryID"; parameter.SourceVersion=DataRowVersion.Original; DataSetdataSet=newDataSet(); dataAdpater.Fill(dataSet,"Categories"); DataRowrow=dataSet.Tables["Categories"].Rows[0]; row["CategoryName"]="NewCategory"; dataAdpater.Update(dataSet,"Categories");
插入、更新和删除的排序
在许多情况下,以何种顺序向数据源发送通过DataSet作出的更改是相当重要的。
例如,如果已更新现有行的主键值并且添加了具有新主键值的新行,则务必要在处理插入之前处理更新。
可以使用DataTable的Select方法来返回仅引用具有特定RowState的DataRow数组。然后可以将返回的DataRow数组传递到DataAdapter的Update方法来处理已修改的行。通过指定要更新的行的子集,可以控制处理插入、更新和删除的顺序。
示例如下:
DataTabletable=dataSet.Tables["Customers"]; //Firstprocessdeletes. adapter.Update(table.Select(null,null,DataViewRowState.Deleted)); //Nextprocessupdates. adapter.Update(table.Select(null,null, DataViewRowState.ModifiedCurrent)); //Finally,processinserts. adapter.Update(table.Select(null,null,DataViewRowState.Added));
三、使用sql语句更新
例如:
cmd=newOleDbCommand(string.Format(@"insertintoworker(workerid,workername,password,phoneno)values("{0}","{1}","{2}","{3}")",textBox1.Text,textBox2.Text,textBox3.Text,textBox4.Text),oc); oc.Open(); try { inti=cmd.ExecuteNonQuery(); } catch(Exceptionex) { }
性能的优劣及使用的情形,还未完全明白。
一般的,绑定bindingsource,用datatable绑定bindingsource(实质上绑定的是datatable。defaultview,同时可用到dataview的筛选功能,但是在筛选完后,filter要重置为null,否则出现的一直是经过筛选的数据)
其他:
使用builder的作用:
OleDbCommandBuildercb=newOleDbCommandBuilder(da);
这个主要是为了让C#自动为OleDbDataAdapterda生成相对应的DeleteCommand,UpdateCommand!
希望本文所述对大家的C#数据库程序设计有所帮助。
相关文章
- mysql executereader_C# 操作MySQL数据库, ExecuteReader()方法参数化执行T-SQL语句, 游标读取数据…
- 【小5聊】C#基础之Response.ContentType响应内容类型[通俗易懂]
- c#设计登录界面并添加数据库_windows窗体连接数据库
- c# mysql executenonquery_C#与数据库访问技术总结(八)之ExecuteNonQuery方法
- c# mysql executenonquery_C#与数据库访问技术之ExecuteNonQuery方法
- c#面试题抽象类和接口的区别-金三银四面试:C#程序员经常遇到的30道基础面试题,想你所想
- 【愚公系列】2023年02月 .NET/C#知识点-List转成字符串的总结
- C# 可空值类型详解编程语言
- C程序操作MySQL数据库的锁表实现方法(c# mysql 锁表)
- C与MySQL结合实现处理图片的功能(c# mysql 图片)
- .NET(C#)连接各类数据库代码-集锦
- c#获取数据库中所有表名称的方法
- C#泛型相关讲解
- C#灰度化图像的实例代码
- C#连接MySql数据库的方法
- C#中Convert.ToInt32()和int.Parse()的区别介绍
- C#正则表达式分解和转换IP地址实例(C#正则表达式大全c#正则表达式语法)
- 支持多类型数据库的c#数据库模型示例
- C#基础知识系列八const和readonly关键字详细介绍
- c#操作sqlserver数据库的简单示例
- c#扩展datatable转json示例
- C#把数字转换成大写金额的代码实例
- C#中Invoke和BeginInvoke的真正涵义
- C#结合数据库实现验证识别ID卡内容的方法