在执行对表中数据的查询时还能将数据保存到 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. 【cf比赛练习记录】Codeforces Round #579 (Div. 3)

    思考之后再看题解,是与别人灵魂之间的沟通与碰撞 A. Circle of Students 题意 给出n个数,问它们向左或者向右是否都能成一个环.比如样例5是从1开始向左绕了一圈 [3, 2, 1, ...

  2. Oracle in不超过1000,List<String>参数拆分,代码举例

    public Map<String,Map<String, Object>> getConsInfo(List<String> consIdList) { Map& ...

  3. dedecms 织梦二级菜单的调用

    <ul class="nav navbar-nav navlist"> <li class='nav-item'> <a href="htt ...

  4. SDN初体验(软件定义网络实验一)

    作业说明 本次实验步骤2.3是在机房环境下完成的,步骤1.4是在自己笔记本上重新配置完成的,所以环境.用户名什么的会略有差别. 1. 安装轻量级网络仿真工具Mininet 为了节约课程时间,实验室机房 ...

  5. 安装关系型数据库MySQL和大数据处理框架Hadoop

    1. 简述Hadoop平台的起源.发展历史与应用现状.列举发展过程中重要的事件.主要版本.主要厂商:国内外Hadoop应用的典型案例. (1)Hadoop的介绍: Hadoop最早起源于Nutch,N ...

  6. 正则表达式在线分析 regex online analyzer

    https://regexper.com/#%2F%5B0-9%5D%5Cs%5B0-9%5D%2F https://regexper.com/ http://regexone.com/lesson/ ...

  7. redis 服务器开放给其他电脑连接

    1.云服务器的端口6379开通 2.宝塔服务器上的6379开通 3.修改服务器上的redis配置文件: # bind 127.0.0.1 注释掉daemonize no 改为noprotected-m ...

  8. java String 转Json报错 java.lang.NoClassDefFoundError: org/apache/commons/lang/exception/NestableRuntim

    这个问题就是缺少jar包依赖!!! java.lang.NoClassDefFoundError: org/apache/commons/beanutils/DynaBean 缺少commons-be ...

  9. 筛选出dataframe中全为数字的列的值

    In [1]: import pandas as pd In [2]: import numpy as np In [3]: students = [ ('jack', 'Apples' , 34) ...

  10. 如何基于EasyDSS流媒体RTMP、HLS(m3u8)、HTTP-FLV、RTSP服务器体系的全套SDK完成各种场景下的视频应用需求

    需求背景 回顾EasyDSS的发展过程,基本上保持的是先局部后系统.先组件后平台的发展方式,一步一步夯实每一个细节功能点,从最基础.最兼容的音视频数据的拉流获取,到高效的.全兼容的数据推流,再到流媒体 ...