在执行对表中数据的查询时还能将数据保存到 DataSet 中,但需要借助 DataAdapter 类来实现。

在实际应用中,DataAdapter 与 DataSet 是在查询操作中使用最多的类。

此外,还可以通过 DataSet 实现对表中数据的增加、修改、删除操作。

DataAdapter 与 DataSet 类简介

  DataAdapter 类用于将数据表中的数据查询出来并添加到 DataSet 中,DataAdapter 在 System.Data.SqlClient 命名空间下   对应的类名是 SqlDataAdapter。

  SqlDataAdapter 类的主要构造方法如下表所示。

构造方法 说明
SqlDataAdapter(SqlCommand cmd) 带参数的构造方法,传递 SqlCommand 类的对象作为参数
SqlDataAdapter(string sql, SqlConnection conn) 带参数的构造方法,sql 参数是指定对数据表执行的 SQL 语句,conn 是数据库的连接对象
SqlDataAdapter() 不带参数的构造方法

  从 SqlDataAdapter 类的构造方法可以看出,SqlDataAdapter 类需要与 SqlCommand 类和 SqlConnection 类一起使用。

  SqlDataAdapter 类常用的属性和方法如下表所示。

属性或方法 说明
SelectCommand 属性,设置 SqlDataAdapter 中要执行的查询语句
InsertCommand 属性,设置 SqlDataAdapter 中要执行的添加语句
UpdateCommand 属性,设置 SqlDataAdapter 中要执行的修改语句
DeleteCommand 属性,设置 SqlDataAdapter 中要执行的删除语句
Fill(DataSet ds) 方法,将 SqlDataAdapter 类中查询出的结果填充到 DataSet 对象中
Fill(DataTable dt) 方法,将 SqlDataAdapter 类中查询出的结果填充到 DataTable 对象 中,DataTable是数据表对象,在一个DataSet对象中由多个 DataTable对象构成
Update(DataSet ds) 方法,更新 DataSet 对象中的数据
Update(DataTable dt) 方法,更新 DataTable 对象中的数据

  DataSet 类是一种与数据库结构类似的数据集,每个 DataSet 都是由若干个数据表构成的,DataTable 即数据表,每个        DataTable 也都是由行和列构成的,行使用 DataRow 类表示、列使用 DataColumn 类表示。

  此外,用户还可以通过 DataRelation 类设置数据表之间的关系。

  下面介绍 DataSet 类以及 DataTable 类的使用。

1) DataSet 类

  DataSet 类中的构造方法如下表所示。

构造方法 说明
DataSet() 无参构造方法
DataSet(string DataSetName) 带参数的构造方法,DataSetName 参数用于指定数据集名称

  DataSet 类中常用的属性和方法如下表所示。

属性或方法 说明
Tables 属性,获取 DataSet 中所有数据表的集合,Tables[0] 代表集合中的第一个数据表
CaseSensitive 属性,获取或设置 DataSet 中的字符串是否区分大小写
Relations 属性,获取 DataSet 中包含的关系集合
Clear() 方法,清空 DataSet 中的数据
Copy() 方法,复制 DataSet 中的数据
AcceptChanges() 方法,更新 DataSet 中的数据
HasChanges() 方法,获取 DataSet 中是否有数据发生变化
RejectChanges() 方法,撤销对 DataSet 中数据的更改

2) DataTable

  DataTable 作为 DataSet 中的重要对象,其与数据表的定义是类似的,都是由行和列构成,并有唯一的表名。

  从 SqlDataAdapter 类的填充方法 (Fill) 中可以看出允许将数据直接填充到 DataTable 中,这样既能节省存储空间也能简    化查找数据表中的数据。

  DataTable 中常用的构造方法如下表所示。

构造方法 说明
DataTable()  无参构造方法
DataTable(string TableName) 带参数的构造方法, TableName 参数用于指定数据表的名称

  DataTable 与 DataSet 有很多相似的属性和方法,在下表中列出了一些与 DataSet 类不同的属性。

属性 说明
TableName 属性,获取或设置 DataTable 的名称
Columns 属性,获取 DataTable 中列的集合
Rows 属性,获取 DataTable 中行的集合
DataSet 属性,获取 DataTable 所在的 DataSet
Constraints 属性,获取 DataTable 中的所有约束

使用 DataSet 和 DataTable 类存放查询结果

  在实际应用中,将查询结果存储到 DataSet 类或 DataTable 类中均可,在操作查询结果时也非常类似。

  string sql = "SELECT * FROM UserAlertTable ORDER BY datetime desc;";
  DataSet ds = new DataSet();
  using (SqlConnection con = new SqlConnection(str))
  {
    con.Open();
    SqlCommand cmd = new SqlCommand(sql, con);
    SqlDataAdapter adapter = new SqlDataAdapter(cmd);
    //adapter.SelectCommand = new SqlCommand("SELECT * FROM UserAlertTable WHERE id = 18 ORDER BY datetime desc",con);
    adapter.Fill(ds);
    adapter.Update(ds);
  }
  if (ds.Tables[0].Rows.Count > 0)
  {
    for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
    {
      WriteLine(ds.Tables[0].Rows[i]["datetime"]);
    }
  }

  http://c.biancheng.net/view/3026.html

ADO.NET 五(DataAdapter 与 DataSet)的更多相关文章

  1. Winform开发之ADO.NET对象Connection、Command、DataReader、DataAdapter、DataSet和DataTable简介

    ADO.NET技术主要包括Connection.Command.DataReader.DataAdapter.DataSet和DataTable等6个对象,下面对这6个对象进行简单的介绍:(1)Con ...

  2. dataAdapter与dataSet和dataTable的填充

    对于dataAdapter与dataSet和dataTable的填充,可以分为1对1,1对n,n对n,3种情况. 以SqlDataAdapter为例. //(1)1对1 SqlDataAdapter ...

  3. 30、ADO.NET、事务、DataSet

    ADO.NET ADO.NET是一组用于和数据源进行交互的面向对象类库.通常数据源是数据库,但也可以是文本文件.Excel表格.XML文件. 说白了就是使用.net操作数据库的一套类库. ADO.NE ...

  4. 【ADO.NET】8、DataSet的使用

    一.DataSet的查询 SqlDataReader 适用于大型数据的读取,它是一条一条的读取,读取出来的数据是存放在服务器上当正在读取数据的时候,突然与服务中断,将无法读取后面的数据DataSet ...

  5. ADO.NET获取数据(DataSet)同时获取表的架构

    普通的ADO.NET获取DataSet的写法如下: using System.Configuration; using System.Data; using System.Data.SqlClient ...

  6. ADO.NET_包括DataReader和dataSet的使用

    今天总结了一下ADO.NET编程中DataReader和dataSet两个比较重要的对象的使用,完成了combobox,listbox,以及fpSpread动态添加数据的测试,对使用sqlComman ...

  7. DataAdapter与DataSet的使用

    1.创建数据库连接: 2.创建数据适配器(Adapter); 3.创建容器数据集(DataSet); 4.从数据集中取出指定表: 5.遍历表数据并输出: using System; using Sys ...

  8. 【转】ADO.NET中的五个主要对象

    Connection 物件    Connection 对象主要是开启程序和数据库之间的连结.没有利用连结对象将数据库打开,是无法从数据库中取得数据的.这个物件在ADO.NET 的最底层,我们可以自己 ...

  9. ADO.NET中的DataSet和DataReader

    ADO.NET提供两个对象用于检索关系型数据并把它存储在内存中,分别是DataSet和DataReader.DataSet提供内存中关系数据的表现--包括表和次序.约束等表间的关系的完整数据集合.Da ...

随机推荐

  1. vuejs cli3 env配置文件实践指南

    env文件 配置四个环境名字分别 VUE_APP_ENV=dev 只支持:VUE_APP_ 开头,比如设置其它变量 VUE_APP_NAME=stark package.json 配置 方式 &quo ...

  2. [Beta]第十次 Scrum Meeting

    [Beta]第十次 Scrum Meeting 写在前面 会议时间 会议时长 会议地点 2019/5/20 22:00 20min 大运村公寓6F寝室 附Github仓库:WEDO 例会照片 工作情况 ...

  3. Oracle存储过程 函数 计算使用资源

    目录 存储过程与函数 存储过程的优势 存储过程 打印语句 选择语句 函数 计算使用资源 存储过程与函数 存储过程的优势 存储过程 /* 多行注释 */ -- 单行注释 //展示错误信息 show er ...

  4. 一、JavaScript基础

    一.区分大小写 ECMAScript中的一切(变量.函数名和操作符)都区分大小写,(js用于行为交互.数据交互.逻辑交互) 二.标识符 指变量.函数.属性的名字,或者函数的参数 命名规则:1.第一个字 ...

  5. js实现字符串切割并转换成对象格式保存到本地

    // split() 将字符串按照指定的规则分割成字符串数组,并返回此数组(字符串转数组的方法) //分割字符串 var bStr = "www.baidu.con"; var a ...

  6. post 发送方式

    /** * post 方式 解码 */ public static String getWebContentByPost(String urlString, String data, final St ...

  7. Python - Django - form 组件自定义校验

    reg2.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  8. Centos7安装图形界面桌面

    查看是否存在图形安装包.如果包含GNOME Desktop,则说明已存在. yum grouplist 安装图形化包 yum groupinstall "GNOME Desktop" ...

  9. [LeetCode] 251. Flatten 2D Vector 压平二维向量

    Implement an iterator to flatten a 2d vector. For example,Given 2d vector = [ [1,2], [3], [4,5,6] ] ...

  10. 画图前端:mermaid。时序图/类图/甘特图/流程图/状态图/饼图。类似工具:Typora

    文档 https://mermaidjs.github.io/#/ cdn https://www.bootcdn.cn/mermaid/ 在线编辑 https://mermaidjs.github. ...