文档详情

ODBC数据源连接.doc

发布:2017-02-03约7.16千字共9页下载文档
文本预览下载声明
ODBC编程的有关知识 ODBC是一个函数级接口标准,它为C/C++、BASIC等高级程序设计语言开发应用程序提供了访问各种数据源的统一标准。 一、ODBC的基本概念 什么是ODBC 开放式数据库互连(Open Database Connectivity,ODBC)是微软公司开放服务体系中有关数据库的一个组成部分,它建立了一组规范并提供一组访问数据库的标准API。ODBC提供了设计、开发独立于DBMS的应用能力。应用程序可以利用SQL来完成其大部分数据库访问任务,有助于实现应用程序和数据库的分离。提高应用系统的数据访问透明性和可移植性。 ODBC的结构 ODBC通过驱动程序提供数据独立性。驱动程序与具体的数据库有关,但基于ODBC的应用程序对数据库的操作不依赖于任何DBMS,也不直接与DBMS交互,所有的数据库操作由对应数据库服务器的ODBC驱动程序完成。也就是说,不论何种数据库,均可以通过ODBC API进行访问。 (1)应用程序 (Application):定义了系统的应用逻辑,负责和用户的交互管理,它调用ODBC函数向数据库库服务器提交数据访问请求,获取结果并返回给用户。 (2)ODBC 管理器 (ODBC manager),它为应用程序加载和调用ODBC驱动程序,负责应用程序和驱动程序的交互控制。但应用程序需要执行ODBC函数时,它会根据应用程序提供的连接数据源找到它相应的驱动程序,并将驱动程序中同名的函数和应用程序绑定。 ODBC管理器由Microsoft提供。Microsoft随他们的产品提供了好几种。并且你总可从数据库提供商那里获得新的ODBC 驱动程序。只要简单地安装新的ODBC驱动程序你的机器就可使用新的它以前不知道的数据库。SQLAllocEnv,SQLAllocConnect和SQLAllocStmt,这样可以达到兼容和代码重用作用。SQLAllocEnv:用来分配环境句柄。例如: Dim rc As Integer ODBC函数的返回码 Dim henv As LongODBC环境句柄 rc = SQLAllocEnv(henv) 获取ODBC环境句柄SQLAllocConnect:用来分配连接句柄。连接句柄提供对一些信息的访问,例如,在连接上的有效语句及标识符句柄,以及当前是否打开一些一个事务处理。调用SQLAllocConnect 函 数 获 取 连 接 句 柄。例如:Dim hdbc As Long 连接句柄rc = SQLAllocConnect(henv, hdbc) 获取连接句柄ODBC驱动程序完成。 建立的连接方式有三种: SQLConnect、SQLDriverConnect 和SQLDriverConnect SQLConnect:最简单的方式 例 如: Dim DSN As String, UID As String, PWD As String DSN = DataSourceName ODBC数据源名称 UID = UserID 用户帐号 PWD = Password 用户口令 rc = SQLConnect(hdbc, DSN, Len(DSN), UID,Len(UID), PWD, Len(PWD)) 建立连接。 其中:hdbc,已经分配的连接句柄,DSN 、UID和 PWD分别是数据源、用户名和用户密码。 SQLDriverConnect 交互式连接的方法。应用程序根据驱动程序的规格说明为参数inconnectionstring SQLDriverConnect:可以多次调用以创建到数据源的有效ODBC连接。 分配语句句柄 用户对DBC数据源的存取操作,都是通过SQL语句实现的。在这个过程中,应用程序 将通过连接向ODBC数据库提交SQL语句,以完成用户请求的操作SQLAllocHandle或SQLAllocStmt来分配语句句柄。调用SQLAllocStmt 函数获取语句句柄。例如:Dim hstmt As Long rc = SQLAllocStmt(hdbc, hstmt) 执行SQL语句 执行SQL语句。 执行SQL 语 句 的方法比较多, 最简单明了的方法是调用SQLAllocStmt 函数,例如: Dim SQLstmt As String SQLstmt = SELECT * FROM authors rc = SQLExecDirect(hstmt, SQLstmt, Len(SQLstmt)) 如果SQL语句被顺利提交并正确执行, 那么就会产生一个结果集。检索结果集的方法有很多,最简单最直接的方法是调用SQLFetch 和SQLGetData 函 数。SQL
显示全部
相似文档