📄 01_9_14_7.asp.html
字号:
<html><head><meta http-equiv='Content-Type' content='text/html; charset=gb2312'>
<TITLE>计算机世界网-利用VC++获取异构型数据库库结构信息</TITLE></HEAD>
<style>
.a14{font-size:14px;text-indent:25px;line-height:20px}
.f{font-size:18px;color=#0f3ccd}
img{border:0px;}
td,p,input{font-fammily:verdana,宋体;font-size:12px;}
A:link {text-decoration:none;color:black}
A:visited {text-decoration:none;color:#80006f}
A:hover {text-decoration:underline;color:black}
</style>
<center>
<BODY topmargin=2 leftmargin=0>
<style>
.v12{font-size:10pt;color:"#ffffff";FONT-WEIGHT: bold}
.v14{font-size:14px;text-indent:25px;line-height:20px}
img{border:0px;}
td,p,input,select{font-fammily:verdana,宋体;font-size:12px;}
A:link {text-decoration:none;color:black}
A:visited {text-decoration:none;color:#80006f}
A:hover {text-decoration:underline;color:black}
</style>
<style>
.v13{font-size:10pt;color:"#ffffff";FONT-WEIGHT: bold}
.v12{font-size:13px;color:"#4C029C";FONT-WEIGHT: bold}
.v14{font-size:14px;text-indent:25px;line-height:20px}
img{border:0px;}
td,p,input,select{font-fammily:verdana,宋体;font-size:12px;}
A:link {text-decoration:none;color:black}
A:visited {text-decoration:none;color:#80006f}
A:hover {text-decoration:underline;color:black}
</style>
<!--头-->
<table align=center cellpadding="0" cellspacing="0" border="0" width="767">
<tr><td valign=bottom>
<table cellpadding="0" cellspacing="0" border=0>
<tr><td valign=top><img src="../../../../../center/image/ccwlogo.gif"></td></tr>
<tr><td height="27" valign=top><img src="../../../../../center/image/knowledge.gif" width="207" height="27"></td></tr>
</table></td>
<td valign=bottom width=556 bgcolor="#4c029c" height=96>
<table cellpadding="0" cellspacing="0" border=0 width=556 bgcolor="#4c029c" height=96>
<tr><td height=25 valign=bottom bgcolor="#ffffff" colspan=2 ><img src="../../../../../image2002/top.gif" usemap="#F"></td></tr>
<tr valign=middle >
<td align=center valign=middle height="60" align=center>
<!-- <a href="http://www.ccw.com.cn/search/" target=_blank><img src="../../../../../img2/esearch.GIF" border=0 width=468 height=60></a> --><a href="http://www.ccw.com.cn/html/search/thememail/" target=_blank><img src="../../../../../img2/topbanner_thememail.GIF" border=0 width=468 height=60></a>
</td>
<td align=center width=15%>
<table width=95%>
<tr><td><a href="mailto:center@ccw.com.cn?subject=我要投稿:" target=_blank><font class=v13>我要投稿</a><br><a href="mailto:center@ccw.com.cn?subject=编读往来"><font class=v13>编读往来</a><br><a href="javascript:AddBookMark('计算机世界网首页')"><font class=v13>加入收藏</a></font></td></tr>
</table>
</td>
</tr>
<tr><td bgcolor="#ffffff" height=1 colspan=2 ></td></tr>
<tr><td bgcolor="#b4aafc" height=2 colspan=2 ></td></tr></table>
<map name="F">
<area href="http://www.ccw.com.cn/" shape="rect" coords="29, 3, 61, 18" target=_blank>
<area href="http://www.ccw.com.cn/news1/" shape="rect" coords="72, 3, 143, 18" target=_blank>
<area href="http://www.ccw.com.cn/center/" shape="rect" coords="155, 2, 216, 18" target=_blank>
<area href="http://www.ccw.com.cn/work/" shape="rect" coords="225, 2, 299, 18" target=_blank>
<area href="http://www.ccw.com.cn/search/" shape="rect" coords="310, 3, 364, 19" target=_blank>
<area href="http://www3.ccw.com.cn/" shape="rect" coords="372, 2, 412, 19" target=_blank>
<area href="http://www2.ccw.com.cn/" shape="rect" coords="424, 2, 550, 18" target=_blank></map>
</td></tr>
<tr><td colspan=2 bgcolor="#b4aafc">
<table border=0 cellpadding=0 cellspacing=0 width=100%>
<tr>
<td width=26% align=center><font class=v12>【2003年6月24日】 </font></td>
<td CLASS=V12> <a href="http://www.ccw.com.cn/center/topic.asp">专 题</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/tech.asp">技 术</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/prod.asp">产 品</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/app.asp">应 用</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/net.asp">网 络</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/prog.asp">编 程</a> /</td>
<td CLASS=V12><a href="http://www.ccw.com.cn/center/skill.asp">技 巧</a> </td>
</tr>
</table>
</td></tr>
</table>
<table align=center width=728>
<tr><td align=center><br><h2><font color='#0f3ccd'>利用VC++获取异构型数据库库结构信息</font></h2>
<br><b>空军电讯工程学院计算机室 万映辉 邸晓奕</b>
</td></tr><tr><td align=right>01-9-14 下午 02:41:22<br><hr size=1 width=718 color=#f46240></td></tr></table><br>
<table align=center width=728><tr><td valign=top width=600>
<table width=100% ><tr>
<td class=a14><b>一. 问题的提出</b></td>
</tr></table><table width=100% ><tr>
<td class=a14> 随着数据库技术在各个应用领域的迅速发展,市场上推出了多种数据库系统,为了充分利用资源,实现信息共享,以便用户能对异构型数据库实现透明的访问(包括数据查询、更新和交换等功能),作者开发了异构型数据库通信平台。在平台的研制过程中,获取各种异构型数据库的结构信息是进行数据访问的前提。作者以VC++5.0为开发语言,利用ODBC实现了这一关键技术。</td>
</tr></table><table width=100% ><tr><td class=a14>
</td></tr></table><table width=100% ><tr>
<td class=a14> <b>二. ODBC技术介绍</b></td>
</tr></table><table width=100% ><tr>
<td class=a14> ODBC技术是指开放性数据库连接技术,该技术使应用程序无需关心数据源来自何种DBMS,利用其标准接口实现与数据源之间的数据交换。传统的ODBC编程是利用高级语言(如C语言)调用ODBC的API来实现。应用程序要求驱动程序管理器和每个驱动程序为ODBC环境、每个连接以及每个SQL语句分配信息存储空间,并返回指向各个存储区的句柄供其调用。ODBC接口定义了三种句柄类型:</td>
</tr></table><table width=100% ><tr><td class=a14>
环境句柄:为全程信息标识内存存储,包括有效连接句柄及当前活动连接句柄。ODBC将环境句柄定义为HENV类型的变量。应用程序使用单一环境句柄,它必须在连接到数据源前请求该句柄。</td></tr></table><table width=100% ><tr>
<td class=a14> 连接句柄:为特定连接的信息标识了内存存储。ODBC将连接句柄定义为HDBC类型。应用程序必须在连接到数据源前请求连接句柄。每个连接句柄与环境句柄有关。然而,环境句柄可以有多个与其有关的连接句柄。</td>
</tr></table><table width=100% ><tr><td class=a14>
语句句柄:为SQL语句信息标识内存存储。ODBC将语句句柄定义为HSTMT类型变量。应用程序必须在提交SQL请求之前请求语句句柄。每个语句句柄与一个连接句柄有关。然而,每个连接句柄可以有多个与其相关的语句句柄。</td></tr></table><table width=100% ><tr><td class=a14>
下面以C语言为例说明传统ODBC编程的一般过程。</td></tr></table><table width=100% ><tr><td class=a14>
1、 环境申请,分配环境句柄</td></tr></table><table width=100% ><tr><td class=a14>
HENV henv;</td></tr></table><table width=100% ><tr><td class=a14>
SQLAllocEnv(&henv);</td></tr></table><table width=100% ><tr><td class=a14>
说明:分配一个环境句柄,支持一个或多个数据源连接。</td></tr></table><table width=100% ><tr><td class=a14>
2、 连接申请,分配连接句柄</td></tr></table><table width=100% ><tr><td class=a14>
HDBC hdbc;</td></tr></table><table width=100% ><tr><td class=a14>
SQLAllocConnect(henv,&hdbc);</td></tr></table><table width=100% ><tr><td class=a14>
说明:一个连接句柄对应一个数据源,可以有多个连接句柄。</td></tr></table><table width=100% ><tr><td class=a14>
3、 连接数据源,用连接句柄连接到数据源</td></tr></table><table width=100% ><tr><td class=a14>
SQLDriverConnect(hdbc,...);</td></tr></table><table width=100% ><tr><td class=a14>
说明:以对话框方式获取注册信息,并连接数据源。</td></tr></table><table width=100% ><tr><td class=a14>
4、 语句申请,分配语句句柄</td></tr></table><table width=100% ><tr><td class=a14>
SQLAllocStmt(hdbc,&hstmt);</td></tr></table><table width=100% ><tr><td class=a14>
说明:获得语句句柄,以便执行SQL语句。</td></tr></table><table width=100% ><tr><td class=a14>
5、 执行SQL语句</td></tr></table><table width=100% ><tr><td class=a14>
SQLExecDirect(hstmt,SQLStatement,..);</td></tr></table><table width=100% ><tr><td class=a14>
说明:利用语句句柄,执行SQL语句。</td></tr></table><table width=100% ><tr><td class=a14>
6、 释放所有资源</td></tr></table><table width=100% ><tr><td class=a14>
SQLfreeStemt(hstmst,...); //释放语句句柄</td></tr></table><table width=100% ><tr><td class=a14>
SQLDisconnect(hdbc); //断开连接</td></tr></table><table width=100% ><tr><td class=a14>
SQLFreeConnect(hdbc); //释放当前数据库连接句柄</td></tr></table><table width=100% ><tr><td class=a14>
SQLFreeEnv(henv); //释放环境句柄</td></tr></table><table width=100% ><tr><td class=a14>
</td></tr></table><table width=100% ><tr>
<td class=a14> <b>三. 利用VC++和ODBC技术获取异构型数据库结构信息</b></td>
</tr></table><table width=100% ><tr><td class=a14>
传统的ODBC编程过程比较复杂,各种参数不易理解,且直接获取返回的数据较困难。VC++ 5.0的MFC类库对ODBC的API进行封装,部分简化了ODBC编程(尤其是对数据库记录集的操作),但单纯利用MFC类获取异构型数据库的结构信息仍然比较困难,因此需要将MFC和传统ODBC API编程结合起来。作者利用ODBC接口函数重载了MFC中CRecordset类的部分成员函数,创建CTable和CColumns类。利用这两个新创建的类,可以很方便的获取异构型数据库结构信息。</td></tr></table><table width=100% ><tr><td class=a14>
下面就是关于CTable和Ccolumns类的定义:</td></tr></table><table width=100% ><tr><td class=a14>
class CTable : public CRecordset</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
virtual CString GetDefaultConnect() { return ""; }</td></tr></table><table width=100% ><tr><td class=a14>
virtual CString GetDefaultSQL() { return ""; }</td></tr></table><table width=100% ><tr><td class=a14>
public:</td></tr></table><table width=100% ><tr><td class=a14>
CTable(CDatabase* pDatabase);</td></tr></table><table width=100% ><tr><td class=a14>
BOOL Open(LPCSTR pszTableQualifier = NULL,</td></tr></table><table width=100% ><tr><td class=a14>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -