码迷,mamicode.com
首页 > Web开发 > 详细

ADO.NET中5大对象简介

时间:2014-06-05 11:56:40      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:c   style   blog   a   http   tar   

ADO.NET中5大对象简介

ADO.NET在以前的学习中接触过,并以应用过,但并没有好好的总结过。最近这段时间的学习又复习了这块的知识,下面就我现在所知道的总结归纳一下。

ADO.NET是基于XML的全新的数据库访问技术,与传统的ADO相比,它主要核心z是XML,
它是一个断开式连接,它主要依靠的是DataSet数据集。


一、ADO.NET对象模型,如下图。

bubuko.com,布布扣

        .NET数据提供程序和DataSet是ADO.NET中的两个重要组件

        .NET数据提供程序:保证了客户端和服务器的连接(即,应用程序和数据库之间的连接)

    .NET数据提供程序主要是两种,一个是SQL.NET数据提供程序,一个是OLE DB.NET数据提供程序.

    SQL.NET数据提供程序,它能够对SQL Server数据库进行操作。

    OLE DB.NET数据提供程序,它可以连接SQL Server数据库,还可以连接除SQL Server以外的数据库。

bubuko.com,布布扣

        下图中描述了SQL.NET数据提供程序和OLE DB.NET数据提供程序中使用Connection对象,命名空间的引入和连接字符串串的差别。

bubuko.com,布布扣




二、ADO.NET中5大对象的概述

    (1)Connection对象:连接数据库。具体连接方法,如上图所示。


    (2)Command对象:执行一些简单操作命令,如:增删改删。即执行T-SQL语句。

     Command对象在执行的的时候有几个比较重要的方法,如ExecuteNonQuery方法,执行增删改命令。查询方法有2种:一个是ExecuteReader方法,返回一个DataReader对象。还有ExecuteScale方法,返回首行首列。


    (3)DataAdapter对象:数据适配器,从数据库中检索数据,再填充到本地数据集中。同时,我们可以利用DataAdapter,再将数据反向从DataSet中更新回数据库。

      DataAdapter使用中主要有4个命令对象比较重要。它们分别是:SelectCommand、InsertCommand、UpdateCommand、DeleteCommand.

       SelectCommand,主要是从数据库中检索数据,InsertCommand、UpdateCommand、DeleteCommand这3个命令对象主要负责把本地数据集DataSet中的数据上传回服务器。

       DataAdapter的Fill方法,用于使用DataAdapter的SelectCommand的结果来填充DataSet。

      

    (4)DataReader对象:是一个只向前的数据流。用于从数据源中检索只读数据集,并且必须有连接时才可以用。


    (5)DataSet对象:是ADO.NET的核心,相当于本地数据库,它与数据库无关的,它和远程数据库连接的桥梁就是.NET数据提供程序。它是由多个表构成,每个表都是一个DataTable对象。

    DataSet中主要的对象时DataTable,每一列都是DataColumn对象,每一行都是一个DataRow对象。在里面可以加入一些约束,一个是UniqueConstraint(唯一约束),一个是ForeignKeyConstraint(外键约束)。

    DataSet下面有两个重要的集合,一个是DataTables,一个是DataRelations.DataTables里面放置的都是DataTable对象。


    本文从理论的角度,概述了ADO.NET中5大对象的作用,要想更好的理解ADO.NET,只有在做项目中不断的去应用它,才能体会的更深刻。



ADO.NET中5大对象简介,布布扣,bubuko.com

ADO.NET中5大对象简介

标签:c   style   blog   a   http   tar   

原文地址:http://blog.csdn.net/haiyan_cf/article/details/27233173

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!