📄 01_9_14_7.asp.html
字号:
SQL_API_SQLTABLES,&bFunctionExists));</td></tr></table><table width=100% ><tr><td class=a14>
if (!Check(nRetCode) || !bFunctionExists)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
if (!bFunctionExists)</td></tr></table><table width=100% ><tr><td class=a14>
TRACE(_T("SQLTables 不支持\n"));</td></tr></table><table width=100% ><tr><td class=a14>
return FALSE;</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr><td class=a14>
//设置缓冲区状态,分配语句句柄 </td></tr></table><table width=100% ><tr><td class=a14>
SetState(nOpenType,NULL,readOnly);</td></tr></table><table width=100% ><tr><td class=a14>
if (!AllocHstmt())</td></tr></table><table width=100% ><tr><td class=a14>
return FALSE;</td></tr></table><table width=100% ><tr><td class=a14>
TRY</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
OnSetOptions(m_hstmt);</td></tr></table><table width=100% ><tr><td class=a14>
AllocStatusArrays();</td></tr></table><table width=100% ><tr><td class=a14>
//调用 ODBC的SQLTables函数</td></tr></table><table width=100% ><tr><td class=a14>
AFX_ODBC_CALL(::SQLTables(m_hstmt,</td></tr></table><table width=100% ><tr><td class=a14>
(UCHAR FAR*)pszTableQualifier,SQL_NTS,</td></tr></table><table width=100% ><tr><td class=a14>
(UCHAR FAR*)pszTableOwner,SQL_NTS,</td></tr></table><table width=100% ><tr><td class=a14>
(UCHAR FAR*)pszTableName,SQL_NTS,</td></tr></table><table width=100% ><tr><td class=a14>
(UCHAR FAR*)pszTableType,SQL_NTS));</td></tr></table><table width=100% ><tr><td class=a14>
if (!Check(nRetCode))</td></tr></table><table width=100% ><tr><td class=a14>
ThrowDBException(nRetCode,m_hstmt);</td></tr></table><table width=100% ><tr><td class=a14>
// 分配内存,填写信息</td></tr></table><table width=100% ><tr><td class=a14>
AllocAndCacheFieldInfo();</td></tr></table><table width=100% ><tr><td class=a14>
AllocRowset();</td></tr></table><table width=100% ><tr><td class=a14>
MoveNext();</td></tr></table><table width=100% ><tr><td class=a14>
m_bBOF = m_bEOF;</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr><td class=a14>
//异常信息的捕获</td></tr></table><table width=100% ><tr><td class=a14>
CATCH_ALL(e)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
Close();</td></tr></table><table width=100% ><tr><td class=a14>
THROW_LAST();</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr><td class=a14>
END_CATCH_ALL</td></tr></table><table width=100% ><tr><td class=a14>
return TRUE;</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr><td class=a14>
void CTable::DoFieldExchange(CFieldExchange* pFX)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
pFX->SetFieldType(CFieldExchange::outputColumn);</td></tr></table><table width=100% ><tr><td class=a14>
RFX_Text(pFX,_T("TABLE_QUALIFIER"),m_strTableQualifier);</td></tr></table><table width=100% ><tr><td class=a14>
RFX_Text(pFX,_T("TABLE_OWNER"),m_strTableOwner);</td></tr></table><table width=100% ><tr><td class=a14>
RFX_Text(pFX,_T("TABLE_NAME"),m_strTableName);</td></tr></table><table width=100% ><tr><td class=a14>
RFX_Text(pFX,_T("TABLE_TYPE"),m_strTableType);</td></tr></table><table width=100% ><tr><td class=a14>
RFX_Text(pFX,_T("REMARKS"),m_strRemarks);</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr><td class=a14>
以上两个类对CRecordset的Open和DoFieldExchange函数进行了重载。应用程序可以在需要时创建CTable或Ccolumns类,并调用OPEN成员函数建立相应的表结构和字段结构记录集。接下来就可以通过下列函数来遍历异构型数据库的结构信息了。</td></tr></table><table width=100% ><tr><td class=a14>
Void CRecordset::MoveFirst(); //移到第一条记录</td></tr></table><table width=100% ><tr><td class=a14>
Void CRecordset::MoveLast(); //移到最后一条记录</td></tr></table><table width=100% ><tr><td class=a14>
Void CRecordset::MovePrev(); //移到前一条记录</td></tr></table><table width=100% ><tr><td class=a14>
Void CRecordset::MoveNext(); //移到后一条记录</td></tr></table><table width=100% ><tr><td class=a14>
BOOL CRecordset::IsBOF(); //判断是否到达第一条记录前</td></tr></table><table width=100% ><tr><td class=a14>
BOOL CRecordset::IsEOF(); //判断是否到达最后一条记录后</td></tr></table><table width=100% ><tr><td class=a14>
</td></tr></table><table width=100% ><tr>
<td class=a14> <b>四、结束语</b></td>
</tr></table><table width=100% ><tr><td class=a14>
利用自定义的CTable和Ccolumns类,应用程序能获取任何异构型数据库库结构信息。根据获得的信息可以方便的对未知数据库进行相应的操作。若将CTable和Ccolumns类与文档类、视类结合起来,就可以在窗口里以一定的方式显示结构信息。作者利用以上技术在异构型数据库通信平台上成功实现了对各种异构型数据库库结构信息的获取。</td></tr></table><table width=100% ><tr><td class=a14>
</td></tr></table><table width=100% ><tr><td class=a14>
</td></tr>
</table><br>
<style>.a1{font-size:1}</style>
<table width=100% ><tr><td align=right>(网页编辑:<a href='mailto:liu_yang@ccw.com.cn'>风之翼</a>)</td></tr></table>
</td><td class=a1 bgcolor=#f46240> </td>
<td valign=top width=138 align=right><table width=98% ><tr><td>
<form action='/app/gsearch1.asp' name=pdn><table width=100% ><tr><td>应用与方案
频道全文检索</td></tr>
<tr><td><input type="text" name="textfile" size=15 value=频道内检索 onfocus="this.value=''">
<input border=0 src="../../../../../images/jian.gif" name="I1" type="image" align=absmiddle>
</td></tr>
</table>
</form>
<form name=srch action="/search/which.asp" method=post onsubmit="JavaScript:return chk()">
<table width=100% >
<tr><td><select size="1" name="func">
<option selected value="2">主题检索</option>
<option value="1">周报全文检索</option>
<option value="3">模糊词检索</option>
</select></td></tr>
<tr><td><input type="text" name="SrchStr" size=15 value="输入待检索的词"
onfocus="this.value=''">
<input src="../../../../../images/jian.gif" name="I1" type="image" align="absMiddle" border=0>
</td></tr>
</table>
<script language="JavaScript">
function chk()
{if (!document.srch.SrchStr.value){
alert("请输入需检索的词!");
document.srch.SrchStr.focus();
return false;
}
else{if (document.srch.SrchStr.value.length>30){
alert("检索的词请不要超过30个字符!");
document.srch.SrchStr.focus();
return false;
}
}
}
</script></form>
<table width=100% ><tr><td class=f colspan=2><b>相关文章</b></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_14_6.asp.html'>在Visual C++中用ADO进行数据库编程</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_14_5.asp.html'>使用OLEDB编写数据库应用程序</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_14_4.asp.html'>在VC中使用ADO开发数据库应用程序</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_14_3.asp.html'>用Visual C++开发数据库应用程序</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_14_2.asp.html'>单独使用CRecordSet</a></td></tr>
</table>
</td></tr></table></td></tr></table><br>
<table align=center width=680><tr><td align=right>
<form name=mail method=post action='/pub/subMail.asp' onsubmit='JavaScript: return chkField(this)'>
<INPUT type='hidden' name='rec' value='24215'>
您的姓名:<INPUT type="text" name=myName size=10>
您朋友的E-mail:<INPUT type="text" name=friendMail size=10>
<INPUT type="submit" value="推荐给好友">
</form>
</td></tr>
<tr><td align=right>
<b>[<a href="javascript:window.close()">关闭窗口</a>]</b>
</td></tr>
</table>
<script language="javascript">
function chkField(fmObj)
{if (!fmObj.friendMail.value){
alert("请输入您朋友的E-mail!");
fmObj.friendMail.focus();
return false;
}
return true;
}
</script>
<table align=center width=680>
<tr><td><hr size=1 width=660 color=#f46240></td></tr>
</table><br>
<p align=center>Copyright(C) ccw.com.cn,All rights reserved</p>
<p align=center><b>中国计算机世界出版服务公司版权所有</b></p>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -