C#数据适配器DataAdapter

 更新时间:2022年05月12日 08:23:09   作者:springsnow  
这篇文章介绍了C#中的数据适配器DataAdapter,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、填充数据

DataSet ds = new DataSet();
SqlCommand cmd = new SqlCommand("select * from Catogories;select * from Customers", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);//da可以多次使用于不同的SelectCommand.CommandText
DataTableMapping map = da.TableMappings.Add("Table", "Customer");//参数依次为,数据源中表,DataSet中的表
map.ColumnMappings.Add("Name", "CustomerName");
//da.MissingMappingAction= MissingMappingAction.Ignore;
da.MissingSchemaAction = MissingSchemaAction.AddWithKey;//用于处理模式冲突,默认为Add。
da.Fill(ds);//新增的DataTable表名默认为"Table",而后新增的表名默认为Table1,Table2等。
da.Fill(ds, "Customer");
da.Fill(ds, 0, 10000, "Customer");//用于分页填充
da.FillSchema(ds, System.Data.SchemaType.Source, "Customer");//仅仅填充模式信息

如果连接未打开,则会自动打开,Fill后自动关闭,如还需要使用此连接,需要重新打开。如果conn手工已打开,Fill后需要手动关闭连接。

二、将多个DataTable插入Tables集合

1、使用多个DataAdapter填充

SqlCommand cmd = new SqlCommand("select * from Catogories;s", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds, "Catogories");

cmd.CommandText = "select * from Customers";
SqlDataAdapter da2 = new SqlDataAdapter(cmd);
da2.Fill(ds, "Customer");

2、使用同一个DataAdapter,用不同的SelectCommandText填充

SqlCommand cmd = new SqlCommand("select * from Catogories;s", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds, "Catogories")

da.SelectCommand.CommandText = "select * from Customers";
da.Fill(ds, "Customer");

3、返回多个结果集的SQL(推荐)

SqlCommand cmd = new SqlCommand("select * from Catogories;select * from Customers", conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds);

三、使用DataAdapter更新数据

DataSet dsChanged = ds.GetChanges();
if (dsChanged != null)
{
    SqlCommandBuilder builder=new SqlCommandBuilder(da);
    //自动生成InsertCommand,UpdateCommand,DeleteCommand命令,前提是:Select语句为单表,同时此语句包含主键或唯一列
    da.Update(ds,"Author");//Update方法检测DataSet中的每条记录,如果行状态不为Unchanaged,根据其行状态调用不同的SQL语句。
    ds.AcceptChanges();
}
  • DataTable.AcceptChanges方法:提交自上次调用AcceptChanges以来对该表进行的所有更改。  
    所有Added和Modified行成为Unchanged;Deleted行被移除。  
  • DataTable.RejectChanges方法:回滚自该表加载以来或上次调用AcceptChanges以来对该表进行的所有更改。  
    Added被移除。DataRowState为Modified或Deleted的行返回到其初始状态。 

四、使用SQL

OleDbDataAdapter da = new OleDbDataAdapter();
OleDbCommand cmd = new OleDbCommand("insert into  [A_Emp_Dept_20190522](empname,line) values (?,?)", conn);
cmd.Parameters.Add(new OleDbParameter("empname", OleDbType.Char, 11, ParameterDirection.Input, false, 0, 0, "empname", DataRowVersion.Current, null));
cmd.Parameters.Add(new OleDbParameter("line", OleDbType.Char, 11, ParameterDirection.Input, false, 0, 0, "line", DataRowVersion.Current, null));
da.InsertCommand = cmd;
//da.InsertCommand.UpdatedRowSource= UpdateRowSource.Both;
DataSet ds = new DataSet();
DataRow row = ds.Tables[0].NewRow();
row["empname"] = "222";
row["line"] = "FBd";
ds.Tables[0].Rows.Add(row);
da.Update(ds);

UpdatedRowSource

  • Both:输出参数和返回的结果集的第一行都可以映射到 DataSet 中已更改的行。
    FirstReturnedRecord:只有返回的结果集的第一行中的数据才可以映射到 DataSet 中已更改的行。
    None:忽略任何输出参数或返回的结果集中的行。
    OutputParameters:只有输出参数才可以映射到 DataSet 中已更改的行

五、DataAdapter事件

  • RowUpdating:在对数据源执行命令前的 Update(DataSet) 过程中发生。
  • RowUpdated:在对数据源执行命令后的 Update(DataSet) 过程中发生。

SqlRowUpdatedEventArgs 类属性

  • Command:获取或设置当调用 SqlCommand 时执行的 Update(DataSet)。
  • Errors:获取当 Command 执行时 .NET Framework 数据提供程序生成的任何错误。 
  • RecordsAffected:通过执行 SQL 语句获取更改、插入或删除的行数。 
  • Row:获取通过 Update(DataSet) 发送的 DataRow。 
  • RowCount:获取在一批更新记录中处理的行数。 
  • StatementType:获取所执行的 SQL 语句的类型。 
  • Status:获取 Command 属性的 UpdateStatus。 
  • TableMapping:获取通过 Update(DataSet) 发送的 DataTableMapping。

到此这篇关于C#数据适配器DataAdapter的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • .NET中的Timer类型用法详解

    .NET中的Timer类型用法详解

    这篇文章主要介绍了.NET中的Timer类型用法,较为详细的分析了Timer类型在各种环境下的用法,需要的朋友可以参考下
    2014-08-08
  • 利用C#实现最基本的小说爬虫示例代码

    利用C#实现最基本的小说爬虫示例代码

    最近在学习c#,碰巧遇到个小说站不错,就索性当个练习,所以这篇文章主要给大家介绍了关于利用C#实现最基本的小说爬虫的相关资料,文中给出了详细的示例代码供大家参考学习,需要的朋友们下面随着小编来一起学习学习吧。
    2017-10-10
  • Unity3D Shader实现动态星空

    Unity3D Shader实现动态星空

    这篇文章主要为大家详细介绍了Unity3D Shader实现动态星空,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • c#字符串去掉空格的二种方法(去掉两端空格)

    c#字符串去掉空格的二种方法(去掉两端空格)

    本文主要介绍了字符串去掉两端空格,并且将字符串中多个空格替换成一个空格的方法,需要的朋友可以参考下
    2014-02-02
  • 浅析C# 结构体struct

    浅析C# 结构体struct

    这篇文章主要介绍了C# 结构体struct 的相关资料,帮助大家更好的理解和学习c#,感兴趣的朋友可以了解下
    2020-08-08
  • C#多线程系列之async和await用法详解

    C#多线程系列之async和await用法详解

    本文详细讲解了C#多线程中async和await的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • C#中自定义事件和委托实例

    C#中自定义事件和委托实例

    这篇文章主要介绍了C#中自定义事件和委托实例的,本文先是阐述了事件的原理,然后讲解了事件和委托的步骤,并给出了实例代码,需要的朋友可以参考下
    2015-01-01
  • C# Socket网络编程实例

    C# Socket网络编程实例

    这篇文章主要介绍了C# Socket网络编程实例,分析了Socket网络通信的原理与具体应用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • C#应用XML作为数据库的快速开发框架实现方法

    C#应用XML作为数据库的快速开发框架实现方法

    这篇文章主要介绍了C#应用XML作为数据库的快速开发框架实现方法,详细介绍了将XML作为数据库的C#桌面应用开发技巧,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • C#模拟http 发送post或get请求的简单实例

    C#模拟http 发送post或get请求的简单实例

    下面小编就为大家带来一篇C#模拟http 发送post或get请求的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06

最新评论