⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 01_9_14_5.asp.html

📁 有用的VC教程,包括编程思想编程技巧程序效率等方面的指导
💻 HTML
📖 第 1 页 / 共 2 页
字号:
extern CComModule _Module;</td></tr></table><table width=100% ><tr><td class=a14>
#include <atlcom.h></td></tr></table><table width=100% ><tr><td class=a14>
#include <atldbcli.h></td></tr></table><table width=100% ><tr><td class=a14>
#include <atldbsch.h> // if you are using schema templates</td></tr></table><table width=100% ><tr><td class=a14>
在stdafx.cpp文件里,加入如下代码。</td></tr></table><table width=100% ><tr><td class=a14>
#include <atlimpl.cpp></td></tr></table><table width=100% ><tr><td class=a14>
CComModule _Module;</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>
在打开数据源,会话,行集对象后就可以获取数据了。所获取的数据类型取决于所用的存取程序,可能需要绑定列。按以下步骤。</td></tr></table><table width=100% ><tr>
      <td class=a14> <i>1、 用正确的命令打开行集对象。</i></td>
    </tr></table><table width=100% ><tr>
      <td class=a14> <i>2、 如果使用CManualAccessor,在使用之前与相应列进行绑定。</i>要绑定列,可以用函数GetColumnInfo,如下所示:</td>
    </tr></table><table width=100% ><tr><td class=a14>
// Get the column information</td></tr></table><table width=100% ><tr><td class=a14>
ULONG ulColumns       = 0;</td></tr></table><table width=100% ><tr><td class=a14>
DBCOLUMNINFO* pColumnInfo  = NULL;</td></tr></table><table width=100% ><tr><td class=a14>
LPOLESTR pStrings      = NULL;</td></tr></table><table width=100% ><tr><td class=a14>
if (rs.GetColumnInfo(&ulColumns, &pColumnInfo, &pStrings) != S_OK)</td></tr></table><table width=100% ><tr><td class=a14>
AfxThrowOLEDBException(rs.m_pRowset, IID_IColumnsInfo);</td></tr></table><table width=100% ><tr><td class=a14>
struct MYBIND* pBind = new MYBIND[ulColumns];</td></tr></table><table width=100% ><tr><td class=a14>
rs.CreateAccessor(ulColumns, &pBind[0], sizeof(MYBIND)*ulColumns);</td></tr></table><table width=100% ><tr><td class=a14>
for (ULONG l=0; l<ulColumns; l++)>/td></tr></table><table width=100% ><tr><td class=a14>
rs.AddBindEntry(l+1, DBTYPE_STR, sizeof(TCHAR)*40, &pBind[l].szValue, NULL, &pBind[l].dwStatus);</td></tr></table><table width=100% ><tr><td class=a14>
rs.Bind();</td></tr></table><table width=100% ><tr>
      <td class=a14> <i>3、 用while循环来取数据。</i>在循环中,调用MoveNext来测试光标的返回值是否为S_OK,如下所示:</td>
    </tr></table><table width=100% ><tr><td class=a14>
while (rs.MoveNext() == S_OK)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
   // Add code to fetch data here</td></tr></table><table width=100% ><tr><td class=a14>
   // If you are not using an auto accessor, call rs.GetData()</td></tr></table><table width=100% ><tr><td class=a14>
}</td></tr></table><table width=100% ><tr>
      <td class=a14> <i>4、 在while循环内,可以通过不同的存取程序获取数据。</i></td>
    </tr></table><table width=100% ><tr><td class=a14>
1) 如果使用的是CAccessor类,可以通过使用它们的数据成员进行直接访问。如下所示:</td></tr></table><table width=100% ><tr><td class=a14>
2) 如果使用的是CDynamicAccessor 或CDynamicParameterAccessor 类,可以通过GetValue或GetColumn函数来获取数据。可以用GetType来获取所用数据类型。如下所示:</td></tr></table><table width=100% ><tr><td class=a14>
while (rs.MoveNext() == S_OK)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
   // Use the dynamic accessor functions to retrieve your</td></tr></table><table width=100% ><tr><td class=a14>
   // data</td></tr></table><table width=100% ><tr><td class=a14>
   ULONG ulColumns = rs.GetColumnCount();</td></tr></table><table width=100% ><tr><td class=a14>
   for (ULONG i=0; i<ulColumns; i++)>/td></tr></table><table width=100% ><tr><td class=a14>
   {</td></tr></table><table width=100% ><tr><td class=a14>
     rs.GetValue(i);</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>
3) 如果使用的是CManualAccessor,可以指定自己的数据成员,绑定它们。就可以直接存取。如下所示:</td></tr></table><table width=100% ><tr><td class=a14>
while (rs.MoveNext() == S_OK)</td></tr></table><table width=100% ><tr><td class=a14>
{</td></tr></table><table width=100% ><tr><td class=a14>
   // Use the data members you specified in the calls to</td></tr></table><table width=100% ><tr><td class=a14>
   // AddBindEntry.</td></tr></table><table width=100% ><tr><td class=a14>
   wsprintf("%s", szFoo);</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>
在运行时决定数据类型,要用动态或手工的存取程序。如果用的是手工存取程序,可以用GetColumnInfo函数得到行集的列信息。从这里可以得到数据类型。</td></tr></table><table width=100% ><tr>
      <td class=a14> <b>四、总结</b></td>
    </tr></table><table width=100% ><tr><td class=a14>
由于现在有多种数据源,,想要对这些数据进行访问管理的唯一途径就是通过一些同类机制来实现,如OLE DB。高级OLE DB结构分成两部分:客户和提供者。客户使用由提供者生成的数据。</td></tr></table><table width=100% ><tr><td class=a14>
就像其它基于COM的多数结构一样,OLE DB的开发人员需要实现很多的接口,其中大部分是模板文件。</td></tr></table><table width=100% ><tr><td class=a14>
当生成一个客户对象时,可以通过ATL对象向导指向一个数据源而创建一个简单的客户。ATL对象向导将会检查数据源并创建数据库的客户端代理。从那里,可以通过OLE DB客户模板使用标准的浏览函数。</td></tr></table><table width=100% ><tr><td class=a14>
当生成一个提供者时,向导提供了一个很好的开端,它们仅仅是生成了一个简单的提供者来列举某一目录下的文件。然后,提供者模板包含了OLE DB支持的完全补充内容。在这种支持下,用户可以创建OLE DB提供者,来实现行集定位策略、数据的读写以及建立书签。</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>
</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>&nbsp;</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_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>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_13_26.asp.html'>使用 OpenGL 来开发模型编辑器</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_13_25.asp.html'>一种将WMF文件转换为TGA文件的简便方法</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='24211'>
您的姓名:<INPUT type="text" name=myName size=10>&nbsp;
您朋友的E-mail:<INPUT type="text" name=friendMail size=10>&nbsp;
<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 + -