原文:asp.net学习之ado.net(无连接模式中的DataAdapter)

在非连接模式下,主要讨论以下对象:DataAdapter。
    DataAdpater的作用是在物理存储模式的数据和内存之间进行数据传递。DataTable是用在内存中表示数据库表。DataSet是内存中表示数据库(表、表关系的集合)。DataView是用于在内存中表示数据库视图。 
    DataAdapter对象在后台使用DataReader对象从数据库中获取数据;DataView对象来对数据进行过滤和排序;DataTable对象可以用来跟踪数据记录的改变情况,并决定是否接受或者拒绝这些改变。

1.DataAdapter对象

DataAdapter对象在物理数据库和内存数据表之间起桥梁的作用。一般用DataAdapter对象从数据库获取数据并装入DataTable对象中,也通过DataAdapter对象将DataTable对象中数据的修改写回到物理数据库。
例1: 一个简单的DataAdapter对象的使用
=== App_Code\DawnDataObject.cs ===

Codepublic class Movie_Disconnect{    private static readonly string  _connectionstring;    static Movie_Disconnect()    {        _connectionstring = WebConfigurationManager.ConnectionStrings["DawnEnterpriseDBConnectionString"].            ConnectionString.ToString();    }    public DataTable GetAll()    {        // 初始化DataAdapter        SqlDataAdapter dad = new SqlDataAdapter("Select Id,Title,Director from Movies", _connectionstring);        // 初始化Table        DataTable dt = new DataTable();        dad.Fill(dt);        return dt;    }} 

=== showMovies.aspx

Code<asp:GridView ID="GridView1" runat="server" DataSourceID="ObjectDataSource1"></asp:GridView><asp:ObjectDataSource ID="ObjectDataSource1" TypeName="DawnDataObject.Movie_Disconnect" SelectMethod="GetAll" runat="server"></asp:ObjectDataSource> 

2.DataAdapter的构造

在例1中,我们看到了如何构造一个SqlDataAdapter对象,并且使用Fill方法把数据表填到一个DataTable中。它看起来是像下面这样子的:

SqlDataAdapter dad = new SqlDataAdapter("Select Id,Title,Director from Movies", _connectionstring);DataTable dt = new DataTable();dad.Fill(dt); 

在以上的例子中,看不到SqlConnection,SqlCommand对象的出象,其实,它们还是隐含存在的,这些对象被SqlDataAdapter对象调用了而已,就连SqlConnection对象的Open()方法的调用也由SqlDataAdapter对象来代劳了。
    如果要显式使用SqlConnection,SqlCommand对象,可以像以下代码这样:
例2: SqlAdapter对象的另外构造方法

public DataTable GetAll(){    DataTable dt = new DataTable();    using(SqlConnection conn = new SqlConnection(_connectionstring)) {        SqlCommand command = new SqlCommand("Select Id,Title,Director from Movies", conn);        SqlDataAdapter dad = new SqlDataAdapter(command);        // 初始化Table        dad.Fill(dt);    }    return dt;} 

以上,可以看出,SqlDataAdapter构造函数可以传入一个SqlCommand对象。在ADO.Net中SqlDataAdapter构造函数可以使用以下几种方法进行构造
     ● SqlDataAdapter(): 无参数,构造后,可以给SqlDataAdapter对象的SelectCommand属性分配一个SqlCommand对象。
         作为补充,SqlDataAdapter还有UpdateCommand、DeleteCommand、InsertCommand属性,这些属性在后面会提到。
     ● SqlDataAdapter(string commandText, SqlConnection connection): 第一个参数为T-SQL语句,第二个参数为一个SqlConnection对象。
        使用这个构造函数时,不需要显式声明SqlCommand对象。
     ● SqlDataAdapter(string commandText, string connectionString): 例1使用的方法,不需要显式声明SqlConnection与SqlCommand对象
     ● SqlDataAdapter(SqlCommand command): 例2使用的方法。

3. SqlDataAdapter的Fill/FillSchema方法

DataAdapter对象的Fill方法,该方法不止可以传入DataTable作为参数,也可以传入DataSet作为参数。
     DataAdapter对象的FillSchema方法,可以向DataSet/DataTable参数添加现有的数据库约束。
     3.1 赋值到DataSet
         因为DataSet是DataTable的集合,所以可以Fill多张表到DataSet对象中。
例3: Fill多张数据表到DataSet对象

private void buttonFillData_Click(object sender, EventArgs e){    DataSet userData = new DataSet();    using (SqlConnection testConnection = new SqlConnection(connectionString))  {        SqlCommand testCommand = testConnection.CreateCommand();        testCommand.CommandText = "Select FirstName, LastName from userTable; Select PermissionType from PermissionsTable";        SqlDataAdapter dataAdapter = new SqlDataAdapter(testCommand);        dataAdapter.Fill(userData);    } // testConnection.Dispose called automatically.} 

3.2 Fill方法的重载
       默认的,当调用SqlDataAdapter.Fill(DataSet)时,并没有指定Table名,所以,要想取得DataSet中的DataTable对象,需要使用Index序号。
       也可以指定当Fill进DataSet时,相应表的TableName属性,当需要指定TableName属性时,调用以下Fill方法:
        public int Fill(DataSet dataSet, string srcTable);
      以下的例子是它们之间的区别:
例4: 调用Fill方法填充到DataSet时,指定TableName属性

    protected void Page_Load(object sender, EventArgs e)    {        if (!IsPostBack)        {            string _connectionstring = WebConfigurationManager.ConnectionStrings["DawnEnterpriseDBConnectionString"].            ConnectionString.ToString();            DataSet ds = new DataSet();            using (SqlConnection conn = new SqlConnection(_connectionstring))            {                SqlCommand command = new SqlCommand("Select Id,Title,Director from Movies", conn);                SqlDataAdapter dad = new SqlDataAdapter(command);                dad.Fill(ds, "Movies");  // 调用Fill方法时,使用TableName                dad.SelectCommand = new SqlCommand("select Id,name from MovieCategories", conn);                dad.Fill(ds);   // 为使用TableName                GridView1.DataSource = ds.Tables["Movies"]; // 使用TableName进行指定                GridView1.DataBind();                GridView2.DataSource = ds.Tables[];  // 使用inde进行指定                GridView2.DataBind();            }        }    } 

Fill被重载的方法有很多,具体可以查看:http://msdn.microsoft.com/zh-cn/library/system.data.sqlclient.sqldataadapter.fill.aspx

    3.3 DataAdapter的FillSchema方法
       SqlDataAdapter 类提供 FillFillSchema 两种方法,这对于加载这些数据很关键。这两种方法均可将信息加载到 DataSet 中。Fill 加载数据本身,而 FillSchema 加载有关特定表的所有可用的元数据(如列名、主键和约束)。处理数据加载的正确方式是先运行 FillSchema,后运行 Fill。例如:
daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");
daAuthors.Fill(dsPubs,"Authors");
        具体的参照以下几篇文章:
        http://msdn.microsoft.com/zh-cn/library/49z48hxc.aspx
        http://support.microsoft.com/kb/314145/zh-cn 
        例5:调用FillSchema方法:
//一般先用FillSchema来填入详细的元数据信息,再用Fill来填充数据,例如:

sqlDataAdapter1.FillSchema(dataSet1,SchemaType.Source,"authors");sqlDataAdapter1.Fill(dataSet1,"authors");DataColumn[] colArr;colArr = dataSet1.Tables["authors"].PrimaryKey;MessageBox.Show("Column Count: " + colArr.Length.ToString());for(int i = ; i < colArr.Length; i++){    MessageBox.Show(colArr[i].ColumnName + "   " + colArr[i].DataType.ToString());}

在上例中,如果不调用FillSchema, 缺省情况下不会填如PrimaryKey信息。
    另外,DataAdapter还有一个MissingSchemaAction属性,该属性可以接受以下Enum值:
      ● Add---在添加新行时向DataTable中添加必须的附加列(默认值)
      ● AddWithKey---在添加新行时向DataTAble中添加所有必须的列。
      ● Error---在添加新行时,如果此行不匹配现在的DataTable,就引发一个错误。
      ● Ignore---在添加新行时,如果此行中包含DataTable中没有的列,那么忽略多余的列。
    ds.MissingSchemaAction = MissingSchemaAction.AddWithkey

asp.net学习之ado.net(无连接模式中的DataAdapter)的更多相关文章

  1. asp.net学习之ado.net(连接模式访问)

    原文:asp.net学习之ado.net(连接模式访问)    ado.net框架支持两种模式的数据访问: 连接模式(Connected)和非连接模式(disconnected).这一节介绍如何使用连 ...

  2. <原>ASP.NET 学习笔记之HTML helper中参数何时会是路由参数,何时又会是query string?

    HTML helper中参数何时会是路由参数,何时又会是query string?   @Html.ActionLink("Edit", "Edit", new ...

  3. 第八周学习笔记-ADO.Net中DataTable的应用

    ADO.Net中DataTable的应用  一.知识点描述 1.概述:DataTable是一个临时保存数据的网格虚拟表(表示内存中数据的一个表),是ADO.Net库中的核心对象. 2.DataTabl ...

  4. asp.net学习之SqlDataSource

    原文:asp.net学习之SqlDataSource 通过 SqlDataSource 控件,可以使用 Web 服务器控件访问位于关系数据库中的数据.其中可以包括 Microsoft SQL Serv ...

  5. asp.net学习之Repeater控件

    asp.net学习之Repeater控件 文章摘自:http://www.cnblogs.com/shipfi/archive/2009/10/19/1585703.html Repeater控件和D ...

  6. asp.net学习资源汇总

    名称:快速入门地址:http://chs.gotdotnet.com/quickstart/描述:本站点是微软.NET技术的快速入门网站,我们不必再安装.NET Framework中的快速入门示例程序 ...

  7. asp.net学习之DataList控件

    asp.net学习之DataList控件   DataList控件与Repeater控件一样由模板驱动,与Repeater控件不同的是: DataList控件默认输出是一个HTML表格.DataLis ...

  8. asp.net学习之 数据绑定控件--List数据绑定控件

    原文:asp.net学习之 数据绑定控件--List数据绑定控件 List控件(如 CheckBoxList.DropDownList.ListBox 和 RadioButtonList 类)继承自L ...

  9. asp.net学习之数据绑定控件、数据源控件概述

    原文:asp.net学习之数据绑定控件.数据源控件概述 1.asp.net数据绑定控件分为三大类,每个类分别进行详细:      ● 列表式数据绑定控件: 列表式数据绑定控件常用来在一个表格内的一个字 ...

随机推荐

  1. 演示基于SDL2.0+FFmpeg的播放器

    SDL是一个跨平台的渲染组件,眼下已经推出到2.0.3版本号,支持Win/Linux/OSX/Android.网上非常多介绍大多是基于SDL1.2版本号的,与2.0版本号有一定的区别,本文演示怎样用S ...

  2. android 网络运营商的名字显示规则(锁定屏幕,下拉列表)

    一:Background & 有关flow MTK Operator name display分为两种类型的手机: 1. Sim卡名称: 从基于引导SIM卡读取IMSI到Spn-conf.xm ...

  3. ant利用先进,ant订单具体解释,ant包,ant包装删除编译jar文件

    在日常的项目开发,经常需要我们可以打包测试.特别是,开发环境是windows.实际情况是linux. 这样的话.一个非常大的程序猿将包,其中将包,这些软件包可能非常大,这里是真正的代码会改变的一部分, ...

  4. C++笔试面试总结

    手游广州某公司书面今天接受采访时.刚进去中午1中场休息.他们公司谁刚刚醒来,一个冷漠打牌,然后去上班.瞬间,这些公司有没有什么好印象,压抑. 接着快2点的时候.发了一份笔试题.大部分题目均在网上的&l ...

  5. Android使用的开发MediaRecorder录制声音

    至 Android 录制声音的应用,Android提供 MediaRecorder 类别.大约MediaRecorder可以参考一个特定的解释<Android开发之MediaRecorder类具 ...

  6. effective c++ 条款4 make sure that objects are initialized before they are used

    1 c++ 类的数据成员的初始化发生在构造函数前 class InitialData { public: int data1; int data2; InitialData(int a, int b) ...

  7. 认识Backbone (一)

    Backbone.js为复杂WEB应用程序提供模型(models).集合(collections).视图(views)的结构.其中模型用于绑定键值数据和自定义事件:集合附有可枚举函数的丰富API: 视 ...

  8. Apple Watch 2.0 数据通讯

    经常会碰到Watch app和WatchKit extension需要访问同一个文件.比如,使用一个自定义的字体,播放多媒体文件.有两种方法完成这个任务. 设计的时候,每个包放一份文件.它们分别访问自 ...

  9. 作为一个新人,如何学习嵌入式Linux?

    作为一个新人.如何学习嵌入式Linux?我一直在问太多次,特写文章来回答这个问题. 在学习嵌入式Linux之前.肯定要有C语言基础.汇编基础有没有无所谓(就那么几条汇编指令,用到了一看就会).C语言要 ...

  10. Could not drop object &#39;student&#39; because it is referenced by a FOREIGN KEY constraint

    1. Find foreign keys SELECT * FROM sys.foreign_keys WHERE referenced_object_id = object_id('Student' ...