ODBC_API访问数据库(完整编排).docx

  1. 1、本文档共26页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
主要内容:ODBC API的体系结构使用ODBC API开发数据库应用程序的一般步骤使用函数SQLAllocHandle分配句柄使用函数SQLConnect、SQLDriverConnect、SQLBrowseConnect连接数据源使用函数SQLPrepare和SQLExecute执行SQL语句使用函数SQLBindCol()绑定数据库字段使用函数SQLGetDiagRec和SQLGetDiagField处理错误使用函数SQLFetch移动数据库记录指针使用ODBC API 进行事务处理使用函数SQLDisconnect断开数据源的连接目录ODBC API 基础3ODBC API句柄3ODBC数据类型5ODBC诊断6使用ODBC API变成建立应用程序8ODBC API编程模型概述8连接数据库11准备并执行SQL语句16获取记录集18记录的添加、删除和更新20错误处理23事务处理23断开数据源连接并释放环境句柄25ODBC API 基础ODBC API句柄ODBC API 实现数据库操作的手段是句柄。在ODBC中,使用不同的句柄(HANDLE)来标志环境(environment)、连接(Connection)、语句(statement)、描述符(description)等。句柄是一个应用程序变量,系统用它来存储关于应用程序的上下文信息和应用程序所用到的一些对象。环境句柄环境是存取数据的全局性背景,与环境相关的是全局的所有信息。例如:环境状态、当前环境状态诊断、当前在环境上分配的连接句柄、每个环境属性的当前设置。在实现ODBC的一段代码(Driver Manager或者驱动程序)中,环境句柄标识包含这个信息的结构。环境句柄在ODBC应用程序中不经常用。他们经常用来调用SQLDataSources和SQLDrivers,又是用来调用函数SQLAllocHandle、SQLEndTran、SQLFreeHandle、SQLGetDiagField和SQLGetDiagReg。环境句柄ODBC中整个上下文的句柄,使用ODBC的每个程序从创建环境句柄开始、以释放环境句柄结束。所有其他的句柄都由环境句柄的上下文来管理。环境句柄在每个应用程序中只能创建一个。连接句柄一个连接包含一个驱动程序和一个数据源。连接句柄标识每个连接。连接句柄定义使用哪个驱动程序和该驱动程序使用的数据源。在执行一段ODBC(Driver Manager或者驱动程序)的代码中,连接句柄标志一个包含连接信息的结构。比如:连接状态、当前连接层诊断、语句句柄和当前连接上分配的描述符、每个连接属性的当前设置。如果驱动程序支持多个同时连接,ODBC并不阻止多个同时的连接。因此,在特定的ODBC环境中,多个连接句柄可能指向不同的驱动程序和数据源、相同的驱动程序和不同的数据源甚至是与相同的驱动程序和数据源的多个连接。一些驱动程序限制他们支持的活动连接数目,SQLGetInfo中的SQL_MAX_DRIVER_CONNECTIONS选项可指定一个特定的驱动程序支持多少个活动连接。与数据源进行连接(SQLConnect、SQLDriverConnect或SQLBrowseConnect)、从数据源上断开(SQLDisconnect)、获取驱动程序及数据源信息(SQLGetInfo)、检索诊断(SQLGetDiagField和SQLGetDiagRec)和执行事务(SQLEndTran)时,都需要使用连接句柄。当设置和获取连接属性(SQLSetConnectAttr)及获取SQL语句内部格式(SQLNativeSql)时,也使用它们。在应用程序中,可在任何适当的时候连接或脱离数据源,但不要轻易的建立或脱离连接。语句句柄一个语句不只是一个SQL语句,它包含所有与那个SQL语句相关的信息,如任何由语句和语句执行中使用的参数建立的结果集。一个语句甚至不需要应用程序的SQL语句。例如,当在一个语句上执行如SQLTables这样的编目函数时,它执行返回表名列表的预定义SQL语句。每个语句由语句句柄标识。一个语句与单个的连接相关,并且在那个连接上可能有多个语句。一些驱动程序限制它们支持活动语句的数目,在SQLGetInfo中SQL_MAX_CONCURRENT_ACTIVITIES选项指定一个驱动程序在单个的连接上支持多少个活动的语句。如果它的结果是未确定的,那么语句被定义成“活动的”,其结果既不是结果集,也不是受INSERT、UPDATE、或DELETE语句影响的行数,或者用多个调用把数据发送到SQLPutData。在实现ODBC(Driver Manager或驱动程序)的一段代码中,语句句柄标识一个包含语句信息的结构,如:语句状态、当前语句层诊断、应用程序变量绑定到语句参数和结果集列的地址、每

文档评论(0)

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

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

1亿VIP精品文档

相关文档