欢迎来到天天文库
浏览记录
ID:40542734
大小:319.01 KB
页数:85页
时间:2019-08-04
《使用ADO访问数据库》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第13章使用ADO访问数据库13.1ASP与ADO13.2建立连接13.3Recordset对象13.4Command对象ASP提供了强大的访问数据库的功能。用ASP访问数据库所使用的是ADO(ActiveXDataObjects)组件。使用ADO编写的ASP程序,不仅能够访问Access数据库,能够访问包括Oracle、MSSQLServer、Sybase等支持OLEDB、ODBC的数据库。13.1ASP与ADO13.1.1ASP与数据库通过ADO对象,ASP可以访问Oracle、Sybase、MSSQ
2、LServer、Access、FoxPro等各种支持ODBC或OLEDB的数据库。也就是说,只要具有某种数据库的ODBC或OLEDB驱动程序,就可以通过ADO访问数据库。ASP、ADO、OLEDB及各种数据库之间的关系如图13-1所示。13.1.2ADO的概念和结构ODBC(OpenDatabaseConnectivity)是微软公司开发的一套开放数据库应用程序的接口规范,是广泛使用的数据库接口。使用ODBC开发数据库应用程序的方法是建立ODBC数据源,通过ODBC接口函数,提交SQL语句并接收执行SQL
3、命令的结果。数据库的底层操作由各个数据库的驱动程序完成。OLEDB是以ActiveX技术为基础的数据访问技术标准。OLEDB基于组件模型;可以访问多种格式的数据,包括数据库的数据和非数据库的数据。OLEDB标准的具体实现是一组API函数。使用OLEDBAPI,可以编写能够访问符合OLEDB标准的任何数据源应用程序。为了使各种流行的编程语言都能编写符合OLEDB标准的应用程序,微软公司在OLEDBAPI之上提供了一种面向对象的、与语言无关的应用程序编写接口,就是ADO。ADO是一项数据库访问技术。ADO具有
4、如下优点。对于程序设计者而言,ADO很容易掌握和使用。ADO能够被VisualBasic、Java、C++、VBScript及Jscript等程序设计语言所支持。ADO能够访问各种支持OLEDB的数据源,也就是说,通过ADO能够访问具有OLEDB驱动程序的数据源。ADO允许C++的程序员访问OLEDB的底层接口。ADO包括7个对象及集合,其主要作用描述如下。(1)Connection对象Connection对象用于建立数据源与ADO应用程序之间的连接。(2)Recordset对象Recordset
5、对象是ADO中最重要的对象之一,是对数据库进行检索后的数据记录集。这个记录集既可以是Command对象返回的查询结果,也可以是直接运行SQL命令产生的查询结果。Recordset对象把数据库检索的结果封装在一起,并通过它的方法和属性提供一种方便、快捷地访问每条记录、每个字段的方法。(3)Command对象Command对象用于定义数据库的查询动作,一般使用SQL命令,也可以使用存储过程。Command对象允许指定参数,其参数通过Parameter对象赋值、使用。(4)Parameter对象Paramete
6、r对象的作用是将存储过程和参数查询所需的参数传递给Command对象。存储过程是SQL语言的过程。一个Command对象上的所有Parameter对象构成Parameters集合。(5)Field对象Field对象能够使我们读取记录集(Recordset)对象中各个字段的字段值。定义在一个Recordset对象上的所有Field对象构成Fields集合。(6)Property对象Property对象能够指明一个ADO对象的属性。所有的Property对象构成Properties集合。这个集合与Connec
7、tion、Command、Recordset或Field对象相关联。(7)Error对象Error对象的作用是返回一个数据库连接(Connection)上产生的错误。ADO对象及集合的关系如图13-2所示。在ADO的对象中,Connection、Command和Recordset三个对象是顶层对象,也是最重要的对象。我们能够单独的创建、释放这三个对象。而其他对象,尽管可以单独创建对象,但是在使用之前,必须与有关的对象相关联。Field、Error和Property对象在其双亲对象存在的情况下才存在,不能单
8、独的创建这些对象。Connection对象用于建立应用程序与数据库的连接。在这个基础之上,可以使用Command对象和Recordset对象对所连接的数据库进行各种操作。Command对象用于定义数据库的查询操作,主要采用SQL语言描述查询动作。Recordset对象对应于Command对象的返回结果。当然Recordset对象也可以直接建立一个Recordset,即不显式地为Recordset创建Connection或Com
此文档下载收益归作者所有