1 / 46
文档名称:

第12章 关系数据库提供的应用程序接口.ppt

格式:ppt   页数:46页
下载后只包含 1 个 PPT 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

第12章 关系数据库提供的应用程序接口.ppt

上传人:中国课件站 2011/10/11 文件大小:0 KB

下载得到文件列表

第12章 关系数据库提供的应用程序接口.ppt

文档介绍

文档介绍:第十二章关系数据库提供的应用程序接口
ODBC
OLE DB
ADO
第12章关系数据库提供的应用程序接口
 
本章重点介绍了ODBC(Open Database Connectivity,开放数据库互连)的特点、体系结构、ODBC DSN的创建过程,以及UDA(Universal Data Access,一致数据访问)技术的两层标准接口OLE DB和ADO。
OLE DB是系统级的编程接口,接口,这组接口封装各种数据库系统的访问操作,为数据处理方和数据提供方建立了标准。OLE DB还提供了一组标准的服务组件,用于提供查询、缓存、数据更新、事务处理等操作。
ADO是应用层级的编程接口。它利用OLE DB 接口来访问数据,因此它适合于C/S(客户/服务器)系统和基于Web的应用,尤其在一些脚本语言中进行数据库访问操作是ADO主要优势。
ODBC
ODBC概述
ODBC(Open Database Connectivity,开放数据库互连)是微软公司开放服务结构(WOSA,Windows Open Services Architecture)中有关数据库的一个组成部分,它提供了一组规范和一组对不同类型的数据库进行访问的标准API(应用程序编程接口)函数。这些API利用SQL来完成其大部分任务。 一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS, 所有的数据库操作由对应的DBMS的ODBC驱动程序完成。即不论是FoxPro、Access还是Oracle数据库,均可用ODBC API进行访问。由此可见,ODBC的最大优点是能以统一的方式处理所有的数据库。
一个完整的ODBC由下列几个部件组成:
(Application)
ODBC应用程序是用一般程序设计语言(如C语言等)编写的程序。 2. ODBC API函数
(Administrator)
该程序位于Windows 95控制面板(Control Panel)的32位ODBC内,其主要任务是管理安装的ODBC驱动程序和管理数据源。
(Driver Manager)
,对用户是透明的。应用程序不能直接调用 ODBC 驱动程序,只可调用ODBC驱动程序管理器提供的ODBC API函数,再由ODBC驱动程序管理器负责把相应的ODBC 驱动程序加载到内存中,同时把应用程序访问数据的请求传送给ODBC驱动程序。
驱动程序
ODBC 驱动程序具体负责把SQL请求传送到数据源的DBMS中,再把操作结果返回到ODBC驱动程序管理器。后者在把结果传送至客户端的应用程序。
每种支持ODBC 的数据库都拥有自己的驱动程序,一种驱动程序只能固定地与对应的数据库通信,不能访问其他数据库。

数据源就是需要访问的数据库。
应用程序若要通过ODBC访问一个数据库,则首先要创建一个数据源,主要工作是指定数据源名(DSN,data source name),使其关联一个目的数据库以及相应的ODBC 驱动程序。所以说,数据源实际上是一种数据连接的抽象,指定了数据库位置和数据库类型等信息。
DSN有三种类型:
(1)系统DSN——即是面向系统全部用户的数据源, 系统中的所有用户都可以使用。
(2)用户DSN——即是仅面向某些特定用户的数据源, 只有通过身份验证才能连接。
(3)文件DSN——即是用于从文本文件中获取数据,提供多用户访问。
各部件之间的关系如下:
工作流程:
应用程序要访问一个数据库,首先必须用ODBC管理器注册一个数据源。ODBC管理器根据数据源提供的数据库位置、数据库类型及ODBC驱动程序等信息,建立起ODBC与具体数据库的联系。应用程序将已创建好的数据源名提供给ODBC,ODBC就能建立起与相应数据库的连接,为访问数据库做好准备。。 在ODBC中,ODBC API函数不能直接访问数据库的,必须通过ODBC驱动程序管理器与数据库交换信息。ODBC驱动程序管理器在应用程序和数据源之间起着转换与管理的作用。
创建ODBC DSN

创建ODBC DSN 是通过使用ODBC管理器来进行。ess DSN的操作步骤。
DSN
(1) 单击Windows任务栏的“开始”按钮,选择“设置”——>“控制面板”,展开“管理工具”,双击“数据源(ODBC)”图标,打开“ODBC数据源管理器”对话框窗口,。
“ODBC数据源管理器”对话框