资源描述
实验七 接口的使用
一. 实验目的:熟悉并掌握一种访问数据库组件的使用方法,这些组件可以是以下几种:ODBC、ADO、ADO.NET、JDBC等,类型不限
二. 实验内容:查找相关资料,熟悉并掌握组件的使用方法、
三实验步骤
1.ODBC(OpenDatabaseConnectivity,开放数据库互连)是微软公司开放服务结构(WOSA,WindowsOpenServicesArchitecture)中有关数据库的一个组成部分,这一技术为访问不同种类的 SQL 数据库提供了通用接口。
ODBC是基于结构查询语言(SQL)的,并以此作为访问数据的标准。该接口提供了互操作性,即一个应用程序可以通过一组公用代码访问不同的DBMS。
配置数据源共有两种方法:
方法一:运行数据源管理工具来进行配置。
方法二:使用Driver Manager 提供的ConfigDsn函数来增加、修改或删除数据源。这种方法特别适用于在应用程序中创建的临时使用的数据源。
2. 给出配置两个不同的数据源的过程。
配置数据源共有两种方法: 方法一:运用数据源管理工具来进行配置。
方法二:使用 Driver Manager 提供的 ConfigDsn 函数来增加、修改或删除数据源。这种方法特别适用于在应用程序中创建的临时使用的数据源。 在本实验中, 我们采用第一种方法创建数据源。 实验中需要同时用到 KingbaseES 和 SQL Server,因此需要分别建立两个数据源,我们将其取名为 KingbaseES ODBC 和 SQLServer。下面是建立这两个数据源的具体步骤。 选择『开始』│『设置』│『控制面板』菜单,在弹出窗口中双击“管理工具”图标进入管理工具界面,双击“数据源(ODBC) ”图标。 1.建立 KingbaseES 数据源。
(1) 选择“系统 DSN”选项,单击【添加(D)…】按钮,系统弹出“创建新数据源”对话框,如图 1 所示:
图 1 数据源管理器
(2) 如图 2 所示,在 ODBC 驱动器程序列表中,选择“Kingbase ODBC Driver” ,单击【完成】按钮,系统弹出“Kingbase ODBC 数据源配置”对话
框, 如图 3 所示。
图 2 创建新数据源
(3) 输入数据源名称、数据库名称以及数据库 IP 地址。图中数据源的名称为KingbaseES ODBC,连接的数据库为“学生课程数据库” ,服务器为 localhost,用户名和口令分别为 SYSTEM 和 MANAGER。注意:KingbaseES 区别大小写。
图 3 Kingbase ODBC 数据源配置
(4) 单击 【保存】 按钮, 这样就创建了一个名为 “KingbaseES ODBC” 的 KingbaseES ODBC 数据源。
(5) 如果要测试和数据源的连接是否成功,可以单击“测试连接” ,系统会根据测试的结果反馈相应的消息框,如图 4 和图 5 所示。
图 4 连接成功
图 5 连接失败
以上五步就建立了一个名为 KingbaseES ODBC 的数据源。
2.建立 SQLServer 数据源。
(1) 选择“系统 DSN”选项,单击【添加(D)…】按钮,系统弹出“创建新数据源”对话框,如图 6 所示:
图6 数据源管理器
(2) 如图 7 所示,在 ODBC 驱动器程序列表中,选择“SQL Server” ,单击【完成】按钮,系统弹出“Create New Data Source to SQL Server”对话框,如图 8 所示。
图 7 创建数据源配置
(3) 如图 8,输入数据源名称和服务器,单击【下一步】按钮。图中数据源的名称为 SQLServer,服务器为(local)。如图 9,选择身份认证方式,输入用户名和密码,用户名和口令分别为 sa 和 sa(请根据实际情况进行修改,并对源代码进行相应的修改)。
图 8 SQLServer 数据源配置(1)
图 9 SQLServer 数据源配置(2)
(4) 连续单击【下一步】按钮,这样就创建了一个名为“SQLServer”的 SQL Server ODBC 数据源。如图 10 所示,将弹出一个提示框,提示即将创建一个新的 ODBC数据源。
图 10 提示框
(5) 如果要测试和数据源的连接是否成功,可以单击“Test Data Source” ,如果连接成功,系统将会显示一个连接成功的消息框,如图 11 所示。
图 11 连接成功
以上五步就建立了一个名为 SQLServer 的数据源。
注: 在创建数据源, 测试连接是否成功时, 如果 KingbaseES 和 SQL Server 未启动服务,则将显示连接失败。启动服务后,再进行测试,连接成功。
2. 使用一种语言基于ODBC编程实现对数据库的访问,可以选择创建表、插入、查询、删除和更新操作等实验。
#include <stdlib.h>
#include <stdio.h>
#include <windows.h>
#include <sql.h>
#include <sqlext.h>
#include <sqltypes.h>
#define SNO_LEN 30
#define NAME_LEN 50
#define DEPART_LEN 100
#define SSEX_LEN 5
int main()
{ /* Step 1 定义句柄和变量 */
//以 king 开头的表示的是连接 KINGBASEES 的变量
//以 server 开头的表示的是连接 SQLSERVER 的变量
SQLHENV kinghenv, serverhenv; //环境句柄
SQLHDBC kinghdbc,serverhdbc; //连接句柄
SQLHSTMT kinghstmt,serverhstmt; //语句句柄
SQLRETURN ret; //结果返回集
SQLCHAR sName[NAME_LEN], sDepart[DEPART_LEN],sSex[SSEX_LEN], sSno[SNO_LEN];
SQLINTEGER sAge;
SQLINTEGER cbAge = 0, cbSno = SQL_NTS, cbSex = SQL_NTS,
cbName = SQL_NTS,cbDepart = SQL_NTS;
/* Step 2 初始化环境 */
//分配环境句柄
ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &kinghenv); ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &serverhenv); //设置管理环境的属性
ret=SQLSetEnvAttr(kinghenv,SQL_ATTR_ODBC_VERSION,(void*)SQL_OV_ODBC3,0);ret=SQLSetEnvAttr(serverhenv,SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0);
/* Step 3 :建立连接 */
//分配连接句柄
ret = SQLAllocHandle(SQL_HANDLE_DBC, kinghenv, &kinghdbc);
ret = SQLAllocHandle(SQL_HANDLE_DBC, serverhenv, &serverhdbc);
ret = SQLConnect(kinghdbc, //连接 KingbaseES
"KingbaseES ODBC",SQL_NTS,
"SYSTEM",SQL_NTS,
"MANAGER",SQL_NTS);
if (!SQL_SUCCEEDED(ret)) //连接失败时返回错误值
return -1;
ret = SQLConnect(serverhdbc, //连接 SQLServer
"SQLServer",SQL_NTS,
"sa",SQL_NTS,
"sa",SQL_NTS);
if (!SQL_SUCCEEDED(ret)) //连接失败时返回错误值
return -1;
/* Step 4 :初始化语句句柄 */
ret = SQLAllocHandle(SQL_HANDLE_STMT, kinghdbc, &kinghstmt); ret=SQLSetStmtAttr(kinghstmt,SQL_ATTR_ROW_BIND_TYPE,(SQLPOINTER)SQL_BIND_BY_COLUMN,SQL_IS_INTEGER ); //设置语句选项
ret = SQLAllocHandle(SQL_HANDLE_STMT, serverhdbc, &serverhstmt);
/* Step 5 :两种方式执行语句 */
/* 预编译带有参数的语句 */
//需要多次执行插入,因此预先声明插入语句
ret = SQLPrepare(serverhstmt, "INSERT INTO STUDENT
(SNO,SNAME,SSEX,SAGE,SDEPT) VALUES (?, ?, ?, ?, ?)", SQL_NTS);
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{
//绑定参数
ret = SQLBindParameter(serverhstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR,SQL_CHAR, SNO_LEN, 0, sSno, 0, &cbSno);
ret = SQLBindParameter(serverhstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR,SQL_CHAR, NAME_LEN, 0, sName, 0, &cbName);
ret = SQLBindParameter(serverhstmt, 3, SQL_PARAM_INPUT, SQL_C_CHAR,SQL_CHAR, 2, 0, sSex, 0, &cbSex);
ret = SQLBindParameter(serverhstmt, 4, SQL_PARAM_INPUT, SQL_C_LONG,SQL_INTEGER, 0, 0, &sAge, 0, &cbAge);
ret = SQLBindParameter(serverhstmt, 5, SQL_PARAM_INPUT, SQL_C_CHAR,SQL_CHAR, DEPART_LEN, 0, sDepart, 0, &cbDepart);
}
/*执行 SQL 语句*/
ret = SQLExecDirect(kinghstmt,"SELECT * FROM STUDENT",SQL_NTS);
if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO)
{ //将结果集中的属性列一一绑定至变量
ret = SQLBindCol(kinghstmt, 1, SQL_C_CHAR,sSno,SNO_LEN, &cbSno);
ret = SQLBindCol(kinghstmt, 2, SQL_C_CHAR, sName, NAME_LEN, &cbName); ret = SQLBindCol(kinghstmt, 3, SQL_C_CHAR, sSex, SSEX_LEN, &cbSex);
ret = SQLBindCol(kinghstmt, 4, SQL_C_LONG, &sAge, 0, &cbAge);
ret = SQLBindCol(kinghstmt, 5, SQL_C_CHAR, sDepart, DEPART_LEN, &cbDepart);
}
/* Step 6 :处理结果集并执行预编译后的语句*/
while ((ret=SQLFetch(kinghstmt)) !=SQL_NO_DATA_FOUND)
{
if(ret== SQL_ERROR) //错误处理
printf("Fetch error\n");
else ret=SQLExecute(serverhstmt); //执行语句
}
/* Step 7 中止处理*/
SQLFreeHandle(SQL_HANDLE_STMT,kinghstmt); //释放 Kingbase 语句句柄
SQLDisconnect(kinghdbc); //断开与 KingbaseES 的连接 SQLFreeHandle(SQL_HANDLE_DBC, kinghdbc); //释放 Kingbase 连接句柄
SQLFreeHandle(SQL_HANDLE_ENV,kinghenv); //释放 Kingbase 环境句柄 SQLFreeHandle(SQL_HANDLE_STMT, serverhstmt); //释放 SQLServer 语句句柄 SQLDisconnect(serverhdbc); //断开与 SQLServer 的连接 SQLFreeHandle(SQL_HANDLE_DBC, serverhdbc); //释放 SQLServer 连接句柄 SQLFreeHandle(SQL_HANDLE_ENV, serverhenv); //释放 SQLServer 环境句柄
return 0;
}
在编写程序的时候,请注意 ODBC 1.0 和 ODBC 2.x、ODBC 3.x 函数使用上的差异,很多函数在 3.x 上已经被替换或丢弃了,因此,必须注意实验使用的版本带来的不同之处。
(3) 实验步骤。
首先,在 VC++6.0 中新建一个 Win32 Console Application 的项目,并将项目命名为ODBCTest。
然后,将已经写好的 ODBCTest.c 文件加入到该项目的 Source Files 中,编译并且执行。 执行完成后, 进入 SQL Server 查询分析器, 对原来为空的 Student 表进行查询 (SELECT * FROM Student) ,可以看见 SQL Server 中 Student 表的数据即为 KingbaseES 中 Student 表的数据备份。
四.实验总结
通过用ODBC方式访问数据库,使我熟悉了使用ODBC来进行数据库应用程序的设计和通过ODBC接口编程访问数据库并对数据库进行操作,为以后的学习和工作奠定了基础。
展开阅读全文