OLEDB and ADO

2024-01-17 15:58
文章标签 ado oledb

本文主要是介绍OLEDB and ADO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

百科名片

OLE DB(OLEDB)是微软的战略性的通向不同的数据源的低级应用程序接口。OLE DB不仅包括微软资助的标准数据接口开放数据库连通性(ODBC)的结构化查询语言(SQL)能力,还具有面向其他非SQL数据类型的通路。 作为微软的组件对象模型(COM)的一种设计,OLE DB是一组读写数据的方法(在过去可能被称为渠道)。OLD DB中的对象主要包括数据源对象、阶段对象、命令对象和行组对象。

目录

定义
简介
组成
功能
OLE DB 结构设计问题
实战应用

编辑本段定义

OLEDB(Object Linking and Embedding,Database,又称为 OLE DB或OLE-DB),一个基于COM的数据存储对象,能提供对所有类型的数据的操作,甚至能在离线的情况下存取数据(比方说,你使用的是你的便携机,你可以毫不费力地看到最后一次数据同步时的数据映像).

编辑本段简介

OLEDB位于ODBC层与应用程序之间. 在你的ASP页面里,ADO是位于OLEDB之上的应用程序. 你的ADO调用先被送到OLEDB,然后再交由ODBC处理. 你可以直接连接到OLEDB层,如果你这么做了,你将看到服务器端游标(recordset的缺省的游标,也是最常用的游标)性能的提升.
OLEDB(OLEDB)是 微软的战略性的通向不同的数据源的低级应用程序接口。OLE DB不仅包括 微软资助的标准数据接口开放数据库连接(ODBC)的 结构化查询语言(SQL)能力,还具有面向其他非SQL数据类型的通路。作为微软的组件对象模型(COM)的一种设计,OLE DB是一组读写数据的方法(在过去可能被称为渠道)。OLE DB中的对象主要包括数据源对象、阶段对象、命令对象和行组对象。使用OLE DB的应用程序会用到如下的请求序列:初始化OLE、连接到数据源、发出命令、处理结果、释放数据源对象并停止初始化OLE。

编辑本段组成

OLEDB标准中定义的新概念----OLEDB将传统的 数据库系统划分为多个逻辑组件,这些组件之间相对独立又相互通信。这种组件模型中的各个部分被冠以不同的名称。例如:数据提供者(Data Provider)是指提供数据存储的 软件组件,小到普通的文本文件、大到主机上的复杂数据库,或者 电子邮件存储,都是数据提供者的例子。有的文档把这些软件组件的开发商也称为数据提供者。
我们要开启如Access 数据库中的数据,必须用ADOT 透过OLEDB 来开启。AT 利用OLEDB 来取得数据,这是因为OLEDB 了解如何和许多种 数据源作沟通,所以对OLEDB有相当程度的了解是很重要的。OLEDB 为一种开放式的标准,并且设计成COM(ComponentObject Model,一种对象的格式。凡是依照COM 的规格所制作出来的组件,皆可以提供功能让其它程序或组件所使用。)组件。OLE DB 最主要是由三个部分组合而成:
OLEDB

  OLEDB

1.Data Providers 数据提供者
凡是透过OLEDB 将数据提供出来的,就是数据提供者。例如SQL Server 数据库中的数据表,或是附文件名为mdb 的Access 数据库档案等,都是Data Provider。
⒉Data Consumers 数据使用者
凡是使用OLEDB 提供数据的程序或组件,都是OLEDB 的数据使用者。换句话说,凡是使用ADO 的应用程序或网页都是OLE DB 的数据使用者。
⒊Service Components 服务组件
数据服务组件可以执行数据提供者以及数据使用者之间数据传递的工作,数据使用者要向数据提供者要求数据时,是透过OLEDB 服务组件的查询处理器执行查询的工作,而查询到的结果则由 指针引擎来管理。

编辑本段功能

使用OLE DB的应用程序会用到如下的请求序列: 初始化OLE 连接到数据源 发出命令 处理结果 释放数据源对象并停止初始化OLE
OLE DB 是 Microsoft 的数据访问模型。它使用 组件对象模型 (COM) 接口,与 ODBC 不同的是,OLE DB 假定 数据源使用的不是 SQL 查询处理器。
Adaptive Server Anywhere 包括一个名为 ASAProv 的 OLE DB 提供程序。该提供程序可用于当前的 Windows 和 Windows CE 平台。
您还可以结合使用 【用于 ODBC 的 Microsoft OLE DB 提供程序】(MSDASQL) 和 Adaptive Server Anywhere ODBC 驱动程序来访问 Adaptive Server Anywhere。
使用 Adaptive Server Anywhere OLE DB 提供程序具有以下几个优点:
·某些功能(如通过 游标更新)不能通过 OLE DB/ODBC Bridge 来使用。
·如果您使用 Adaptive Server Anywhere OLE DB 提供程序,则在部署过程中无需 ODBC。
·MSDASQL 允许 OLE DB  客户端用于任何 ODBC  驱动程序,但不保证您可以使用每个 ODBC 驱动程序的全部功能。而使用 Adaptive Server Anywhere 提供程序,您可以从 OLE DB  编程环境完全访问 Adaptive Server Anywhere 的全部功能。

编辑本段OLE DB 结构设计问题

开始编写 OLE DB 应用程序之前应考虑以下问题:
使用何种 编程实现来编写 OLE DB 应用程序?
Microsoft 提供多种库来解决该问题:OLE DB 模板库、OLE DB 属性以及 OLE DB SDK 中的原始 OLE DB 接口。另外,Microsoft 还提供帮助您编写程序的向导。有关这些实现的更详细的信息,请参见 OLE DB 模板、属性和其他实现。
是否需要编写自己的提供程序?
大多数开发人员无需这样。Microsoft 提供多种提供程序。无论用户何时创建一个 数据连接,例如,当使用 ATL OLE DB 使用者向导向项目中添加使用者时,“数据链接属性”对话框都将列出系统中所有被注册的可用提供程序。如果其中一个提供程序适合于用户自己的 数据存储和数据访问应用程序,最简单的办法就是使用该提供程序。但是,如果用户的 数据存储不适合所提供的类别,则必须创建自己的提供程序。有关创建提供程序的信息,请参见 OLE DB 提供程序模板及其子主题。
需要为自己的使用者提供何种级别的支持?
一些使用者可能非常简单,另一些可能非常复杂。OLE DB 对象的功能由属性指定。使用 ATL OLE DB 使用者向导创建使用者或者使用数据库提供程序向导创建提供程序时,向导将为用户设置合适的对象属性来提供一组标准功能。但是,如果向导生成的使用者类或提供程序类并不具有您需要的所有支持功能,那么您需要查阅这些类在 OLE DB 模板库中的接口。这些接口包装原始 OLE DB 接口,提供附加实现以使其使用起来更加简单。
例如,如果您希望更新行集合中的数据,但在使用向导创建使用者时却忘记指定该功能,则可以在创建使用者之后通过对命令对象设置 DBPROP_IRowsetChange 和 DBPROP_UPDATABILITY 属性来指定该功能。这样,当行集合创建之后,它将具有 IRowsetChange 接口。
您是否有使用其他数据访问技术(ADO、ODBC 或 DAO)的旧版代码?
由于可能有各样各样的技术组合(例如 ADO 组件和 OLE DB 组件一起使用、将 ODBC 代码迁移至 OLE DB 等等),所以  Visual C++ 文档不能涵盖所有的情形。

编辑本段实战应用

1 概述
OLE DB的存在为用户提供了一种统一的方法来访问所有不同种类的 数据源。OLE DB可以在不同的 数据源中进行转换。利用OLE DB, 客户端的开发人员在进行数据访问时只需把精力集中在很少的一些细节上,而不必弄懂大量不同数据库的访问协议。OLE DB是一套通过COM接口访问数据的ActiveX接口。这个OLE DB接口相当通用,足以提供一种访问数据的统一手段,而不管 存储数据所使用的方法如何。同时,OLE DB还允许开发人员继续利用基础数据库技术的优点,而不必为了利用这些优点而把数据移出来。
2 使用ATL使用OLE DB数据使用程序由于直接使用OLE DB的对象和接口设计数据库应用程序需要书写大量的代码。为了简化 程序设计,Visual C++提供了ATL模板用于设计OLE DB数据应用程序和数据提供程序。利用ATL模板可以很容易地将OLE DB与MFC结合起来,使数据库的 参数查询等复杂的编程得到简化。MFC提供的数据库类使OLE DB的编程更具有 面向对象的特性。Viual C++所提供用于OLE DB的ATL模板可分为数据提供程序的模板和数据使用程序的模板。
使用ATL模板创建数据应用程序一般有以下几步骤:
创建应用框架加入ATL产生的 模板类在应用中使用产生的 数据访问对象 不用ATL使用OLE DB数据使用程序利用ATL模板产生数据使用程序较为简单,但适用性不广,不能动态适应数据库的变化。下面我们介绍直接使用MFC OLE DB类来生成数据使用程序。模板的使用OLE DB数据使用者模板是由一些模板组成的,包括如下一些模板,下面对一些常用类作一些介绍。会话类CDataSource类CDataSource类与OLE DB的 数据源对象相对应。这个类代表了OLE DB数据提供程序和 数据源之间的连接。只有当 数据源的连接被建立之后,才能产生会话对象,可以调用Open来打开数据源的连接。 CSession类CSession所创建的对象代表了一个单独的数据库访问的会话。一个用CDataSource类产生的数据源对象可以创建一个或者多个会话,要在数据源对象上产生一个会话对象,需要调用函数Open()来打开。同时,会话对象还可用于创建 事务操作。
CEnumeratorAccessor类CEnumeratorAccessor类是用来访问枚举器查询后所产生的行集中可用数据提供程序的信息的访问器,可提供当前可用的数据提供程序和?CAccessor类代表与访问器的类型。当用户知道数据库的类型和结构时,可以使用此类。它支持对一个行集采用多个访问器,并且,存放数据的 缓冲区是由用户分配的。CDynamicAccessor类CDynamicAccessor类用来在程序运行时动态的创建访问器。当系统运行时,可以动态地从行集中获得列的信息,可根据此信息动态地创建访问器。CManualAccessor类CManualAccessor类中以在程序运行时将列与 变量绑定或者是将参数与变量捆定。行集类CRowSet类CRowSet类封装了行集对象和相应的接口,并且提供了一些方法用于查询、设置数据等。可以用Move()等函数进行记录移动,用GetData()函数读取数据,用Insert()、Delete()、SetData()来更新数据。CBulkRowset类CBulkRowset类用于在一次调用中取回多个行句柄或者对多个行进行操作。CArrayRowset类CArrayRowset类提供用 数组下标进行数据访问。
命令类CTable类CTable类用于对数据库的简单访问,用 数据源的名称得到行集,从而得到数据。CCommand类CCommand类用于支持命令的 数据源。可以用Open()函数来执行SQL命令,也可以Prepare()函数先对命令进行准备,对于支持命令的数据源,可以提高程序的灵活性和健壮性。
在stdafx.h头文件里,加入如下代码。
#includeextern CComModule _Module;#include#include#include // if you are using schema templates在stdafx.cpp文件里,加入如下代码。
#includeCComModule _Module;
决定使用何种类型的存取程序和行集。获取数据在打开 数据源,会话,行集对象后就可以获取数据了。所获取的 数据类型取决于所用的存取程序,可能需要绑定列。按以下步骤。
用正确的命令打开行集对象。如果使用CManualAccessor,在使用之前与相应列进行绑定。要绑定列,可以用函数GetColumnInfo,如下所示:
// Get the column informationULONG ulColumns = 0;DBCOLUMNINFO* pColumnInfo = NULL;
LPOLESTR pStrings = NULL;
if (rs.GetColumnInfo(&ulColumns,&pColumnInfo,&pStrings) != S_OK)AfxThrowOLEDBException(rs.m_pRowset,ⅡD_IColumnsInfo);
struct MYBIND* pBind = new MYBIND【ulColumns】;
rs.CreateAccessor(ulColumns,&pBind【0】,sizeof(MYBIND)*ulColumns);
for (ULONG l=0; l<>rs.AddBindEntry(l+1,DBTYPE_STR,sizeof(TCHAR)*40,&pBind【l】.szValue,NULL,&pBind【l】.dwStatus);
rs.Bind();
用while循环来取数据。
在循环中,调用MoveNext来测试光标的返回值是否为S_OK,如下所示:
while (rs.MoveNext() == S_OK){// Add code to fetch data here// If you are not using an auto accessor,call rs.GetData()}
在while循环内,可以通过不同的存取程序获取数据。如果使用的是CAccessor类,可以通过使用它们的 数据成员进行直接访问。如下所示:
如果使用的是CDynamicAccessor 或CDynamicParameterAccessor 类,可以通过GetValue或GetColumn函数来获取数据。可以用GetType来获取所用 数据类型。如下所示:
while (rs.MoveNext() == S_OK){// Use the dynamic accessor functions to retrieve your// dataULONG ulColumns = rs.GetColumnCount();for (ULONG i=0; i<>{rs.GetValue(i);}}
如果使用的是CManualAccessor,可以指定自己的数据成员,绑定它们。就可以直接存取。如下所示:
while (rs.MoveNext() == S_OK){// Use the data members you specified in the calls to// AddBindEntry.wsprintf("%s",szFoo);}
决定行集的 数据类型在运行时决定数据类型,要用动态或手工的存取程序。如果用的是手工存取程序,可以用GetColumnInfo函数得到行集的列信息。从这里可以得到 数据类型。
3 总结由于现在有多种 数据源,想要对这些数据进行访问管理的唯一途径就是通过一些同类机制来实现,如OLE DB。高级OLE DB结构分成两部分:客户和提供者。
客户使用由提供者生成的数据。就像其它基于COM的多数结构一样,OLE DB的开发人员需要实现很多的接口,其中大部分是模板文件。当生成一个客户对象时,可以通过ATL对象向导指向一个 数据源而创建一个简单的客户。ATL对象向导将会检查 数据源并创建数据库的 客户端代理。从那里,可以通过OLE DB客户模板使用标准的浏览函数。当生成一个提供者时,向导提供了一个很好的开端,它们仅仅是生成了一个简单的提供者来列举某一目录下的文件。然后,提供者模板包含了OLE DB支持的完全补充内容。在这种支持下,用户可以创建OLE DB提供者,来实现行集定位策略、数据的读写以及建立书签。
扩展阅读:
  • 1

    http://en.wikipedia.org/wiki/OLEDB

这篇关于OLEDB and ADO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/616523

相关文章

C#通过ACE OLEDB驱动程序访问 Access和 Excel

ACE 代表 Access Connectivity Engine。它是 Microsoft 提供的一组组件,用于访问和操作 Microsoft Access 数据库以及其他类似的文件格式,如 Excel 工作簿。ACE 主要包括以下几部分: ACE OLEDB 驱动程序:用于通过 OLE DB 提供程序访问 Access 数据库和 Excel 文件。例如,Microsoft.ACE.OLED

vs2013 ADO连接SQL server2012数据库

通常情况下,一个给予ADO的数据库应用使用如下的过程操作数据源里的数据  (1) 创建一个Connection 对象。定义用于连接的字符串信息,包括数据源名称、用户ID、口令、连接超时 、 缺省数据库以及光标的位置。一个 Connection 对象代表了同数据 源的一次会话。可以通过 Connection 对象控 制事务,即执行BeginTrans、CommitTrans 和RollbackT

高级C#开发者的 ADO.NET 数据库操作工具类深入解析与实战

高级C#开发者的 ADO.NET 数据库操作工具类深入解析与实战 目录 高级C#开发者的 ADO.NET 数据库操作工具类深入解析与实战 一、ADO.NET 框架概述 二、DBHelper工具类的设计与实现 三、DBHelper工具类的实操分析 四、DBHelper工具类的高级应用 五、总结与展望 一、ADO.NET 框架概述 1.1 ADO.NET 框架简介 ADO.

vc++,MFC 中,用ado执行sql server语句时,并且对返回值真假判断的例子,即bool类型

MFC VC++ 中的对数据库中的表进行查询,判断SQL语句是否执行成功 若存在返回bool值true(1),若失败返回bool值false(0)。 简单bool类型代码如下: CString sql,Result;sql.Format(_T("select * from [dbo].[%s]"), Name);// Name是所要查找数据库中表的名字BOOL bool_temp

Ado.Net基本操作

这里我用到是SqlServer数据库操作,给大家进行讲解简单的Ado.Net操作,数据库的增删改查 连接数据库 想必大家对数据库字符串都记不住吧,这里我给大家一个简单的操作: 第一步:打开视图 第二步:打开服务器资源管理器 第三步:数据库连接-->鼠标右击 添加连接 第四步:选择Microsoft SQL Server 第五步:根据页面的配置和数据库连接配置一

ADO.NET (二)—— ADO和ADO .NET对比

ADO.NET (二)—— ADO和ADO .NET对比       我们知道ADO.NET的两大核心组件分别是Data Provider和DataSet。如果说 DataSet是ADO.NET的心脏,那么Data Provider绝对是ADO.NET的左臂右膀。 Data  Pro

ADO.NET——DataAdapter对象

DataAdapter对象    来源以及作用:前面我所介绍的ADO.NET对象中,例如Connection对象,Command对象以及DataReader对象,这些对象均属于Data Provider的一部分,而且都是基于连接的。如果,每次我们检索数据库中的表或者行都需要连接一次数据库,那么性能和效率是十分低下的。实际上,ADO.NET提供了基于非连接的核心组件:DataSet。那么存储

ADO.NET——Connection、Command。

.NET Framework 数据提供程序包括四个核心对象Connection,Command,DataReader,DataAdapter、在这,我只简单谈一下与SQL Server中经常使用的对象。连接对象SqlConnection,它是在System.Data.SqlClient的命名空间下使用的。     一、Connection对象     描述:作为Data Provide

ADO.NET 之核心组成对象

引言:在当今数据信息丰富的时代,计算机领域中使用数据库来存储信息和访问信息,但是本身数据库种类有很多,例如SQL Server,Oracle,Access,MySql等,因此,如何能更加高效、更加方便地使用一种统一的数据访问编程模型来对不同的数据库的数据进行操作,此时,强大MS就为广大的开发者提供了基于.NET平台的数据访问编程模型ADO.NET。     1、学习背景: 在敲机房收费

ADO.NET之初步了解

重构的时候就接触过ADO.NET,新闻发布系统的时候遇到了sqlhelp。学习ASP.NET的时候,老师又很详细的讲了。现在总结一下。 简介:            首先,ADO.NET提供了对sql server等数据库的访问。应用程序可以通过ADO.NET连接到数据库,并检索、操作、更新其中的数据。同时他是一组向.net编程人员公开数据访问服务的类。ADO。