使用ODBC API访问数据库.doc

使用ODBC API访问数据库.doc

ID:55633341

大小:168.50 KB

页数:26页

时间:2020-05-21

使用ODBC API访问数据库.doc_第1页
使用ODBC API访问数据库.doc_第2页
使用ODBC API访问数据库.doc_第3页
使用ODBC API访问数据库.doc_第4页
使用ODBC API访问数据库.doc_第5页
资源描述:

《使用ODBC API访问数据库.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、主要内容:ØODBCAPI的体系结构Ø使用ODBCAPI开发数据库应用程序的一般步骤Ø使用函数SQLAllocHandle分配句柄Ø使用函数SQLConnect、SQLDriverConnect、SQLBrowseConnect连接数据源Ø使用函数SQLPrepare和SQLExecute执行SQL语句Ø使用函数SQLBindCol()绑定数据库字段Ø使用函数SQLGetDiagRec和SQLGetDiagField处理错误Ø使用函数SQLFetch移动数据库记录指针Ø使用ODBCAPI进行事务处理Ø使用函数SQLDisconnect断开数据源的连接目录

2、ODBCAPI基础3ODBCAPI句柄3ODBC数据类型5ODBC诊断6使用ODBCAPI变成建立应用程序8ODBCAPI编程模型概述8连接数据库11准备并执行SQL语句16获取记录集18记录的添加、删除和更新20错误处理23事务处理23断开数据源连接并释放环境句柄25ODBCAPI基础ODBCAPI句柄ODBCAPI实现数据库操作的手段是句柄。在ODBC中,使用不同的句柄(HANDLE)来标志环境(environment)、连接(Connection)、语句(statement)、描述符(description)等。句柄是一个应用程序变量,系统用它来存

3、储关于应用程序的上下文信息和应用程序所用到的一些对象。1、环境句柄环境是存取数据的全局性背景,与环境相关的是全局的所有信息。例如:环境状态、当前环境状态诊断、当前在环境上分配的连接句柄、每个环境属性的当前设置。在实现ODBC的一段代码(DriverManager或者驱动程序)中,环境句柄标识包含这个信息的结构。环境句柄在ODBC应用程序中不经常用。他们经常用来调用SQLDataSources和SQLDrivers,又是用来调用函数SQLAllocHandle、SQLEndTran、SQLFreeHandle、SQLGetDiagField和SQLGetD

4、iagReg。环境句柄ODBC中整个上下文的句柄,使用ODBC的每个程序从创建环境句柄开始、以释放环境句柄结束。所有其他的句柄都由环境句柄的上下文来管理。环境句柄在每个应用程序中只能创建一个。2、连接句柄一个连接包含一个驱动程序和一个数据源。连接句柄标识每个连接。连接句柄定义使用哪个驱动程序和该驱动程序使用的数据源。在执行一段ODBC(DriverManager或者驱动程序)的代码中,连接句柄标志一个包含连接信息的结构。比如:连接状态、当前连接层诊断、语句句柄和当前连接上分配的描述符、每个连接属性的当前设置。如果驱动程序支持多个同时连接,ODBC并不阻止

5、多个同时的连接。因此,在特定的ODBC环境中,多个连接句柄可能指向不同的驱动程序和数据源、相同的驱动程序和不同的数据源甚至是与相同的驱动程序和数据源的多个连接。一些驱动程序限制他们支持的活动连接数目,SQLGetInfo中的SQL_MAX_DRIVER_CONNECTIONS选项可指定一个特定的驱动程序支持多少个活动连接。与数据源进行连接(SQLConnect、SQLDriverConnect或SQLBrowseConnect)、从数据源上断开(SQLDisconnect)、获取驱动程序及数据源信息(SQLGetInfo)、检索诊断(SQLGetDiag

6、Field和SQLGetDiagRec)和执行事务(SQLEndTran)时,都需要使用连接句柄。当设置和获取连接属性(SQLSetConnectAttr)及获取SQL语句内部格式(SQLNativeSql)时,也使用它们。在应用程序中,可在任何适当的时候连接或脱离数据源,但不要轻易的建立或脱离连接。1、语句句柄一个语句不只是一个SQL语句,它包含所有与那个SQL语句相关的信息,如任何由语句和语句执行中使用的参数建立的结果集。一个语句甚至不需要应用程序的SQL语句。例如,当在一个语句上执行如SQLTables这样的编目函数时,它执行返回表名列表的预定义S

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

8、如:语句状态、当前语句层诊断、应用程序变量绑定到语句参数和结果集列的地址、每个语

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。