📄 01_9_17_20.asp.html
字号:
dbUpdatableField参数的意思是该字段的值是可变的。</td></tr></table><table width=100% ><tr><td class=a14>
根据字段定义对象在数据库表对象当中生成字段。</td></tr></table><table width=100% ><tr><td class=a14>
TableInfo_>CreateField(*FieldInfo);</td></tr></table><table width=100% ><tr><td class=a14>
在生成了所有的字段之后,将新的数据库表的定义填加到数据库对象当中去。</td></tr></table><table width=100% ><tr><td class=a14>
TableInfo_>Append();</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>
Recordset = new CDaoRecordset(newDatabase);</td></tr></table><table width=100% ><tr><td class=a14>
然后使用SQL语句打开记录集对象。首先把SQL语句记入一个字符串:</td></tr></table><table width=100% ><tr><td class=a14>
CString strQuery = _T("Select * from student");</td></tr></table><table width=100% ><tr><td class=a14>
使用这个字符串打开记录集。</td></tr></table><table width=100% ><tr><td class=a14>
Recordset_>Open(dbOpenDynaset , strQuery); </td></tr></table><table width=100% ><tr><td class=a14>
dbOpenDynaset参数的意思是表示记录集打开的类型。dbOpenDynaset的意思是打开一个可以双向滚动的动态记录集。这个记录集中的记录是使用我们定义的SQL语句对数据库进行查询得到的。这个参数还有另外的两种选择:</td></tr></table><table width=100% ><tr><td class=a14>
dbOpenTable参数指示打开一个数据表类型的记录集,使用这种类型的记录集只能对单一的数据库中的记录进行操纵。</td></tr></table><table width=100% ><tr><td class=a14>
如果使用dbOpenSnapshot参数表示打开的是映像记录集,它实际上是所选择的记录集的一个静态的拷贝,在只需要进行查询操作或者希望制作报表的时候,使用这种记录集比较合适,它不会对数据库中的数据进行修改。</td></tr></table><table width=100% ><tr><td class=a14>
接下来对记录集当中的一个标志位赋值,说明是否要求自动地标记出CACHE当中经改变的记录。使用记录集的时候是DAO把被检索出的记录读入CACHE,所有的操纵都是针对CACHE中的记录进行的,要实现对数据库当中的记录更新必须把CACHE记录中被改变的字段的值写回到数据库文件当中去。这个标志位的作用就是当CACHE中的数据改变的时候,是否需要自动的标记出记录中那些应该被写回的字段。</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>
m_Recordset _>AddNew();</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>Update();</td></tr></table><table width=100% ><tr><td class=a14>
使用AddNew()这个函数可以在数据表记录集或者是动态记录集当中添加新的记录,调用AddNew()之后必须接着调用Update()来确认这个添加动作,将新的记录保存到数据库文件当中去。新的记录在数据库当中的位置取决于当前记录集的类型:如果是动态记录集,新记录都将被插入到记录集的末尾。如果是数据表记录集的话,当数据库表中定义了主键的时候新记录将按照库表的排序规则插入到合适的地方;如果没有定义主键那么新记录也会被插入到记录集的末尾。</td></tr></table><table width=100% ><tr><td class=a14>
用AddNew()会改变记录集的当前记录。只有将当前记录定位在新记录上,才能填写它的数据。所以我们使用MoveLast函数使刚刚添加的记录成为当前记录,然后调用Edit函数对新记录进行编辑。</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>MoveLast();</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>Edit();</td></tr></table><table width=100% ><tr><td class=a14>
依次给新记录的字段进行赋值:</td></tr></table><table width=100% ><tr><td class=a14>
COleVariant var1(m_Name , VT_BSTRT);</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>SetFieldValue(_T("studentName") , var1);</td></tr></table><table width=100% ><tr><td class=a14>
COleVariant var2(m_ID , VT_BSTRT);</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>SetFieldValue(_T("studentID") , var2);</td></tr></table><table width=100% ><tr><td class=a14>
COleVariant var3(m_Class , VT_BSTRT);</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>SetFieldValue(_T("studentClass") , var3);</td></tr></table><table width=100% ><tr><td class=a14>
COleVariant var4(m_SID , VT_BSTRT);</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>SetFieldValue(_T("studentSID") , var4);</td></tr></table><table width=100% ><tr><td class=a14>
COleVariant 这个类封装了WIN32提供的VARIANT这个结构以及对它的操作。这个类当中可以存储多种类型的数据。需要注意的是这种包容能力是通过C语言当中的UNION提供的,就是说一个COleVariant 对象只能保存一种类型的数据。我们先把字段的值装入OLE变体对象,再使用这个变体对象对记录中的字段进行赋值。VT_BSTRT参数的作用是在生成OLE变体对象的时候指示将要封入的数据的类型为字符串。当对所有的字段都结束赋值后,调用Update 函数来保存刚才的修改。</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>Update(); </td></tr></table><table width=100% ><tr><td class=a14>
注意,在调用Update函数之前,如果进行了改变当前记录的操作,那么前面进行的所有的赋值工作都将丢失,而且不会给出任何的警告。</td></tr></table><table width=100% ><tr><td class=a14>
这段代码从记录集中取出一个记录的值,这里同样要用到OLE变体对象。记录集的GetFieldValue将返回一个变体对象,我们首先取得这个变体对象,然后从中取出需要的值。</td></tr></table><table width=100% ><tr><td class=a14>
这里V_BSTRT指示从变体对象当中取出字符串类型的数据。</td></tr></table><table width=100% ><tr><td class=a14>
如何从数据库中删去一个记录呢?首先要使该记录成为当前记录。然后使用Delete函数来执行删除操作。</td></tr></table><table width=100% ><tr><td class=a14>
m_Recordset_>Delete(); </td></tr></table><table width=100% ><tr><td class=a14>
删除之后,我们必须把当前记录更改为其他的记录,以确认这个删除动作。</td></tr></table><table width=100% ><tr><td class=a14>
以上就是在MFC中使用DAO进行数据库操作的方法。</td></tr></table><table width=100% ><tr><td class=a14>
了解了前面的内容,相信您对MFC类库已经有了比较深入的认识,可以使用MFC编写出不错的程序了。下面,我们将向您介绍如何在VISUAL C++集成开发环境之下调试自己的程序。</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_17_19.asp.html'>3.4.1 DAO与ODBC</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_17_18.asp.html'>3.3.3 与文件处理关系密切的类CFile</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='../jiqiao/01_9_17_11.asp.html'>在 Visual C++ 中 建 立 MFC 扩 展 DLL</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='01_9_17_17.asp.html'>3.3.2 实例分析</a></td></tr>
<tr><td valign=top><IMG SRC=../../../../../img2/jiao.gif></td><td><a href='../jiqiao/01_9_17_10.asp.html'>利用MFC实现对象拖放</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='24316'>
您的姓名:<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 + -