第八章数据库编程详解.ppt

  1. 1、本文档共108页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第八章数据库编程详解

句柄及其属性 句柄是32位整数值,代表一个指针。ODBC3.0中分为环境句柄、连接句柄、语句句柄、描述符句柄 。 * 应用程序句柄之间的关系 ?每个ODBC应用程序需要建立一个ODBC环境,分配一个环境句柄,存取数据的全局性背景如环境状态、当前环境状态诊断、当前在环境上分配的连接句柄等; ?一个环境句柄可以建立多个连接句柄,每一个连接句柄实现与一个数据源之间的连接; ?在一个连接中可以建立多个语句句柄,它不只是一个SQL语句,还包括SQL语句产生的结果集以及相关的信息等; ?在ODBC 3.0中又提出了描述符句柄的概念,它是描述SQL语句的参数、结果集列的元数据集合。 * 句柄及其属性 数据类型 ODBC定义了两套数据类型: ?SQL数据类型:用于数据源 ?C数据类型 :用于应用程序的C代码 应用程序可以通过SQLGetTypeInfo来获取不同的驱动程序对于数据类型的支持情况。 * SQL 数据类型 C数据类型 SQL数据类型 数据源之间转换 应用程序变量传送到语句 参数(SQLBindparameter) C数据类型 从结果集列中返回到应用 程序变量(SQLBindcol) 应用程序变量之间转换 ODBC体系结构 ?驱动程序管理器 驱动程序管理器用来管理各种驱动程序,包含在ODBC32.DLL中 。它管理应用程序和驱动程序之间的通信 。主要功能为: ?装载ODBC驱动程序 ?选择和连接正确的驱动程序; ?管理数据源; ?检查ODBC调用参数的合法性; ?记录ODBC函数的调用等。 * ODBC体系结构 ?数据库驱动程序 ?存在原因 ODBC应用程序不能直接存取数据库,其各种操作请求由驱动程序管理器提交给某个RDBMS的ODBC驱动程序,通过调用驱动程序所支持的函数来存取数据库。数据库的操作结果也通过驱动程序返回给应用程序。如果应用程序要操纵不同的数据库,就要动态地链接到不同的驱动程序上。 因此,ODBC通过驱动程序来提供应用系统与数据库平台的独立性 。 * ODBC体系结构 ?数据库驱动程序 ?ODBC驱动程序类型 ?单束 数据源和应用程序在同一台机器上,驱动程序直接完成对数据文件I/O操作,驱动程序相当于数据管理器。 ?多束 支持客户机/服务器、客户机/应用服务器/数据库服务器等网络环境下数据访问,由驱动程序完成数据库访问请求的提交和结果集接收,应用程序使用驱动程序提供的结果集管理接口操纵执行后的结果数据。 * ODBC体系结构 ?ODBC数据源管理 数据源是最终用户需要访问的数据,包含了数据库位置和数据库类型等信息,是一种数据连接的抽象 。数据源对最终用户是透明的 。 ODBC给每个被访问的数据源指定唯一的数据源名(Data Source Name,简称DSN),并映射到所有必要的、用来存取数据的低层软件。在连接中,用数据源名来代表用户名、服务器名、所连接的数据库名等。最终用户无需知道DBMS或其他数据管理软件、网络以及有关ODBC驱动程序的细节。 * ODBC编程 使用ODBC编写的应用程序可移植性好,能同时访问不同的数据库共享多个数据源。 ?ODBC产生原因 ?ODBC体系结构 ?ODBC的工作流程 * ODBC的工作流程 * ?配置数据源 配置数据源有两种方法: (1)运行数据源管理工具来进行配置; (2)使用Driver Manager 提供的ConfigDsn函数来增加、修 改或删除数据源 ODBC的工作流程 * ?初始化环境 没有和具体的驱动程序相关联,由Driver Manager来进行控制,并配置环境属性。应用程序通过调用连接函数和某个数据源进行连接后,Driver Manager才调用所连的驱动程序中的SQLAllocHandle,来真正分配环境句柄的数据结构 。 ODBC的工作流程 * ?建立连接 应用程序调用SQLAllocHandle分配连接句柄,通过SQLConnect、SQLDriverConnect或SQLBrowseConnect与数据源连接 SQLConnect连接函数,输入参数为: (1)配置好的

文档评论(0)

ee88870 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档