使用ODBC API 连接数据库

2026/1/27 8:39:27

主要内容: ?

? ODBC API的体系结构 ?

? 使用ODBC API开发数据库应用程序的一般步骤 ? ? 使用函数SQLAllocHandle分配句柄 ?

? 使用函数SQLConnect、SQLDriverConnect、SQLBrowseConnect连接数据源 ?

? 使用函数SQLPrepare和SQLExecute执行SQL语句 ? ? 使用函数SQLBindCol()绑定数据库字段 ?

? 使用函数SQLGetDiagRec和SQLGetDiagField处理错误 ? ? 使用函数SQLFetch移动数据库记录指针 ? ? 使用ODBC API 进行事务处理 ?

? 使用函数SQLDisconnect断开数据源的连接

目录

ODBC API 基础 ........................................................................................................... 3

ODBC API句柄 .................................................................................................... 3 ODBC数据类型 ................................................................................................... 5 ODBC诊断 ........................................................................................................... 5 使用ODBC API变成建立应用程序 ........................................................................... 7

ODBC API编程模型概述 .................................................................................... 7 连接数据库.......................................................................................................... 10 准备并执行SQL语句 ........................................................................................ 14 获取记录集.......................................................................................................... 16 记录的添加、删除和更新.................................................................................. 18 错误处理.............................................................................................................. 20 事务处理.............................................................................................................. 21 断开数据源连接并释放环境句柄...................................................................... 23

ODBC API 基础

ODBC API句柄

ODBC API 实现数据库操作的手段是句柄。在ODBC中,使用不同的句柄(HANDLE)来标志环境(environment)、连接(Connection)、语句(statement)、描述符(description)等。句柄是一个应用程序变量,系统用它来存储关于应用程序的上下文信息和应用程序所用到的一些对象。

1、 环境句柄

环境是存取数据的全局性背景,与环境相关的是全局的所有信息。例如:环境状态、当前环境状态诊断、当前在环境上分配的连接句柄、每个环境属性的当前设置。

在实现ODBC的一段代码(Driver Manager或者驱动程序)中,环境句柄标识包含这个信息的结构。环境句柄在ODBC应用程序中不经常用。他们经常用来调用SQLDataSources和SQLDrivers,又是用来调用函数SQLAllocHandle、SQLEndTran、SQLFreeHandle、SQLGetDiagField和SQLGetDiagReg。

环境句柄ODBC中整个上下文的句柄,使用ODBC的每个程序从创建环境句柄开始、以释放环境句柄结束。所有其他的句柄都由环境句柄的上下文来管理。环境句柄在每个应用程序中只能创建一个。

2、 连接句柄

一个连接包含一个驱动程序和一个数据源。连接句柄标识每个连接。连接句柄定义使用哪个驱动程序和该驱动程序使用的数据源。在执行一段ODBC(Driver Manager或者驱动程序)的代码中,连接句柄标志一个包含连接信息的结构。比如:连接状态、当前连接层诊断、语句句柄和当前连接上分配的描述符、每个连接属性的当前设置。

如果驱动程序支持多个同时连接,ODBC并不阻止多个同时的连接。因此,在特定的ODBC环境中,多个连接句柄可能指向不同的驱动程序和数据源、相同的驱动程序和不同的数据源甚至是与相同的驱动程序和数据源的多个连接。一些驱动程序限制他们支持的活动连接数目,SQLGetInfo中的SQL_MAX_DRIVER_CONNECTIONS选项可指定一个特定的驱动程序支持多少个活动连接。

与数据源进行连接(SQLConnect、SQLDriverConnect或SQLBrowseConnect)、从数据源上断开(SQLDisconnect)、获取驱动程序及数据源信息(SQLGetInfo)、检索诊断(SQLGetDiagField和SQLGetDiagRec)和执行事务(SQLEndTran)时,都需要使用连接句柄。当设置和获取连接属性(SQLSetConnectAttr)及获取SQL语句内部格式(SQLNativeSql)时,也使用它们。

在应用程序中,可在任何适当的时候连接或脱离数据源,但不要轻易的建立

或脱离连接。

3、 语句句柄

一个语句不只是一个SQL语句,它包含所有与那个SQL语句相关的信息,如任何由语句和语句执行中使用的参数建立的结果集。一个语句甚至不需要应用程序的SQL语句。例如,当在一个语句上执行如SQLTables这样的编目函数时,它执行返回表名列表的预定义SQL语句。

每个语句由语句句柄标识。一个语句与单个的连接相关,并且在那个连接上可能有多个语句。一些驱动程序限制它们支持活动语句的数目,在SQLGetInfo中SQL_MAX_CONCURRENT_ACTIVITIES选项指定一个驱动程序在单个的连接上支持多少个活动的语句。如果它的结果是未确定的,那么语句被定义成“活动的”,其结果既不是结果集,也不是受INSERT、UPDATE、或DELETE语句影响的行数,或者用多个调用把数据发送到SQLPutData。

在实现ODBC(Driver Manager或驱动程序)的一段代码中,语句句柄标识一个包含语句信息的结构,如:语句状态、当前语句层诊断、应用程序变量绑定到语句参数和结果集列的地址、每个语句属性的当前设置。

语句句柄在大多数ODBC函数中使用,它们用于函数绑定参数及结果集列(SQLBindParameter和SQLBindCol)、准备执行语句(SQLPrepare、SQLExecute和SQLExecDirect)、检索元数据(SQLColAttribute和SQLDescribeCol)、取结果(SQLFetch)和检索诊断(SQLGetDiagField和SQLGetDiagRec)。它们还在编目函数(SQLColumns,SQLTables等)和其他一些函数中使用。语句句柄使用SQLAllocHandle分配,使用SQLFreeHandle释放。

4、 描述符句柄

从应用程序或驱动程序来看,描述符就是描述SQL语句的参数或结果集列的元数据集合。因此,描述符可用来担当如下4种角色:

1) 应用程序参数描述符(APD):包含绑定到SQL语句中参数的应用程序缓冲区的信息,如它们的地址、长度和C数据类型。

2) 实现参数描述符(IPD):包含关于SQL语句中参数的信息,如它们的SQL数 据类型、长度、和可控性(nullability)。

3) 应用程序行描述符(ARD):包含绑定到结果集列的应用程序缓冲区的信息, 如它们的地址、长度和C数据类型。

4) 实现行描述符(IRD):包含结果集中列的信息,如它们的SQL数据类型、长 度、和可控性。

四种描述符(一种承担一个角色)在分配语句时自动分配,且总是与那条语句相关。称为自动分配描述符。应用程序还可用SQLAllocHandle分配描述符,称为显示分配描述符。它们根据连接进行分配,并且可以与那个连接上的一条或多条语句关联,来履行那些语句上的APD或ARD的职责。

应用程序可完成ODBC中的大多数操作,而不明确使用描述符。然而,描述符可以为有些操作提供方便的快捷方式。例如,假设一个应用程序想从两套不同的缓冲区插入数据。要用第一套缓冲区,它会反复调用SQLBindParameter来把它们绑定至INSERT语句的参数中,然后再执行该语句。要使用第二套缓冲区,它就会重复这个过程。另一种方法就是在一个描述符中建立起对第一套缓冲区的绑定,在另一个描述符中建立对第二套缓冲区的绑定。要在两套绑定集间切换,


使用ODBC API 连接数据库.doc 将本文的Word文档下载到电脑
搜索更多关于: 使用ODBC API 连接数据库 的文档
相关推荐
相关阅读
× 游客快捷下载通道(下载后可以自由复制和排版)

下载本文档需要支付 10

支付方式:

开通VIP包月会员 特价:29元/月

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:xuecool-com QQ:370150219