北邮大三数据库实验四数据库接口实验

北邮大三数据库实验四数据库接口实验

ID:33638910

大小:298.25 KB

页数:8页

时间:2019-02-27

北邮大三数据库实验四数据库接口实验_第1页
北邮大三数据库实验四数据库接口实验_第2页
北邮大三数据库实验四数据库接口实验_第3页
北邮大三数据库实验四数据库接口实验_第4页
北邮大三数据库实验四数据库接口实验_第5页
资源描述:

《北邮大三数据库实验四数据库接口实验》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实验四数据库接口实验-1实验目的1.通过实验了解通用数据库应用编程接口ODBC的基本原理和实现机制,熟悉主要的ODBC接口的语法和使用方法;2.利用C语言(或其它支持ODBC接口的高级程序设计语言)编程实现简单的数据库应用程序,掌握基于ODBC的数据库访问的基本原理和方法3.学习java语言,并采用jdbc接口方式对数据库进行访问实验内容与步骤1、以教科书第四章关于SQL语言相关内容为基础,课后查阅、自学ODBC接口有关内容,包括ODBC的体系结构、工作原理、数据访问过程、主要API接口的语法和使用方法等。2、以实验二建立的学生数据库为基础,编写C语言(或其它支持OD

2、BC接口的高级程序设计语言)数据库应用程序,按照如下步骤访问数据库(a)Step1.ODBC初始化,为ODBC分配环境句柄(b)Step2.建立应用程序与ODBC数据源的连接(c)Step3.利用SQLExecDirect语句,实现数据库应用程序对数据库的建立、查询、修改、删除等操作(d)Step4.检索查询结果集(e)Step5.结束数据库应用程序3、要求所编写的数据库访问应用程序中使用到以下主要的ODBCAPI函数:(1)SQLALLocEnv:初始化ODBC环境,返回环境句柄(2)SQLALLocConnect:为连接句柄分配内存并返回连接句柄(3)SQLCon

3、nect:连接一个SQL数据资源 (4)SQLDriverConnect连接一个SQL数据资源,允许驱动器向用户询问信息 (5)SQLALLocStmt为语句句柄分配内存,并返回语句句柄(6)SQLExecDirect把SQL语句送到数据库服务器,请求执行由SQL语句定义的数据库访问(7)SQLFetchAdvances将游标移动到到查询结果集的下一行(或第一行)(8)SQLGetData按照游标指向的位置,从查询结果集的特定的一列取回数据(9)SQLFreeStmt释放与语句句柄相关的资源(10)SQLDisconnect切断连接(11)SQLFreeConne

4、ct释放与连接句柄相关的资源(12)SQLFreeEnv释放与环境句柄相关的资源 创建ODBC数据源:实验代码:#include#include#include#include"sql.h"#include"sqltypes.h"#include"sqlext.h"RETCODEretcode;//结果返回集SQLHDBChdbc;//定义链接句柄voidprint();//打印子程序voidSQL(unsignedchar[]);//执行SQL语句子程序intmain(){SQLHANDLEhenv;//

5、定义环境句柄unsignedcharSY[]="experiment2";//ODBC数据源名称unsignedchardb2[]="localhost";//用户名unsignedcharpass[]="";//密码//分配ODBC环境retcode=SQLAllocHandle(SQL_HANDLE_ENV,SQL_NULL_HANDLE,&henv);if(retcode==SQL_SUCCESS

6、

7、retcode==SQL_SUCCESS_WITH_INFO)//声明环境retcode=SQLSetEnvAttr(henv,SQL_ATTR_ODBC_VERS

8、ION,(void*)SQL_OV_ODBC3,0);if(retcode==SQL_SUCCESS

9、

10、retcode==SQL_SUCCESS_WITH_INFO)retcode=SQLAllocHandle(SQL_HANDLE_DBC,henv,&hdbc);//分配连接句柄if(retcode==SQL_SUCCESS

11、

12、retcode==SQL_SUCCESS_WITH_INFO)retcode=SQLConnect(hdbc,SY,SQL_NTS,db2,SQL_NTS,pass,SQL_NTS);//链接if(retcode==SQL_SUCCESS

13、

14、

15、retcode==SQL_SUCCESS_WITH_INFO){print();unsignedcharinsert[]="insertintodbo.coursevalues('C08','计算机网络','51','3','秋')";SQL(insert);print();unsignedcharupdate[]="updatedbo.coursesetcredit=100wherecourse_name='计算机网络'";SQL(update);print();unsignedchardel[]="deletefromdbo.coursewher

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

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

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