直接通过DAO读写Access文件

php中文网
发布: 2016-06-07 15:16:58
原创
1475人浏览过

直接 利用DAO来创建、读写Access 文件 ,总的说来,对比上篇《 直接 通过 ODBC读、写Excel 文件 》来讲,要简单一些。在下面的示例中,我们将用到两种方法:SQL和DAO类函数来混合实现它们,这样做的目地,我想可以使大家更加方便灵活的运用它们来完成你想要

直接利用DAO来创建、读写Access文件,总的说来,对比上篇《直接通过ODBC读、写Excel文件》来讲,要简单一些。在下面的示例中,我们将用到两种方法:SQL和DAO类函数来混合实现它们,这样做的目地,我想可以使大家更加方便灵活的运用它们来完成你想要做的东西。在示例程序中默认指定创建数据库名为:Demo.mdb,内部表名为:DemoTable,写入两个字段:名字和年龄,采用和上一篇读写Excel类似的操作,你也可以根据自己需要来动态改变它们。示例程序运行界面如下所示:

下面让我们来简要看看它的实现步骤:

1. 首先,应确保包含进了afxdao.h头文件,可以在StdAfx.h文件中包含它,如下:

Delphi组件编写者指南 word中文版
Delphi组件编写者指南 word中文版

Delphi组件编写者指南关于《组件编写者指南》翻译的说明 1. 译文中粉红色的部分,是译者认为原文有错误的地方,我已改过,只是用粉红色作了标记; 2. 对于有关“参看”的各章节的页码,我也没有建立页码的关联,因为麻烦,所以只是用原书中的页码值,同时用蓝色加以标记,可以直接删除; 3. 由于原书只分章,没有分节。阅读起来不便。所以,我加了章节的编号,这样更清楚。 4. 书中的“第V部分的其余章节”没有真正的对应部分,所以照译出

Delphi组件编写者指南 word中文版 2
查看详情 Delphi组件编写者指南 word中文版

#include <afxdao.h>         //加入DAO数据库支持</afxdao.h>

2. 声明DAO库及其记录集变量,可在你的实现文件中加入下面代码: CDaoDatabase db;          //数据库<br>CDaoRecordset RecSet(&db);    //记录集3. 接着,先让我们来实现它的创建及写入操作void CRWAccessDlg::OnWriteAccess()<br>{<br>  //获取主程序所在路径,存在sPath中<br>  CString sPath;<br>  GetModuleFileName(NULL,sPath.GetBufferSetLength (MAX_PATH+1),MAX_PATH);<br>  sPath.ReleaseBuffer ();<br>  int nPos;<br>  nPos=sPath.ReverseFind (''\'');<br>  sPath=sPath.Left (nPos);<br>  //默认创建数据名:Demo.mdb,内部表名:DemoTable,表内有二个字段:姓名、年龄<br>  CString lpszFile = sPath + "\Demo.mdb";<br>  <br>  CFileFind fFind;<br>  BOOL bSuccess;<br>  bSuccess=fFind.FindFile(lpszFile);<br>  fFind.Close ();<br>  //是否已有创建好的Demo.mdb<strong>文件</strong>,没有则创建它<br>  if(!bSuccess)<br>  {<br>    db.Create(lpszFile);<br>    CString SqlCmd = "CREATE TABLE DemoTable(Name VARCHAR(20),Age VARCHAR(3));";<br>    db.Execute(SqlCmd);<br>  <br>    //打开已创建的数据表<br>    RecSet.Open(AFX_DAO_USE_DEFAULT_TYPE,<br>      "SELECT * FROM DemoTable", 0);<br>    //加入第一个记录,用SQL语句<br>    db.Execute("INSERT INTO DemoTable (Name,Age) VALUES (''徐景周'',26)");<br>    <br>    //加入第二个记录,用DAO涵数<br>    RecSet.AddNew();<br>    RecSet.SetFieldValue("Name","徐志慧");<br>    RecSet.SetFieldValue("Age","21");<br>    RecSet.Update();<br>    <br>    //加入第三个记录,用DAO涵数<br>    RecSet.AddNew();<br>    RecSet.SetFieldValue("Name","郭徽");<br>    RecSet.SetFieldValue("Age","27");<br>    RecSet.Update();<br>    <br>    //关闭记录集及库<br>    RecSet.Close();<br>    db.Close();<br>    AfxMessageBox("Access<strong>文件</strong>写入成功!");<br>  }<br>  else<br>    AfxMessageBox("Demo.mdb数据库已经创建!");<br>  <br>}4. 最后,让我们来实现它的读取操作。void CRWAccessDlg::OnReadAccess()<br>{<br>  COleVariant var;    // 字段类型<br>  var.ChangeType(VT_BSTR, NULL);<br>  CString strName,strAge,strFile;<br>  //清空列表框<br>  m_AccessList.ResetContent();<br>  //获取主程序所在路径,存在sPath中<br>  CString sPath;<br>  GetModuleFileName(NULL,sPath.GetBufferSetLength (MAX_PATH+1),MAX_PATH);<br>  sPath.ReleaseBuffer ();<br>  int nPos;<br>  nPos=sPath.ReverseFind (''\'');<br>  sPath=sPath.Left (nPos);<br>  strFile = sPath + "\demo.mdb";<br>  db.Open(strFile);    // 打开已创建的demo数据库及DamoTable表<br>  RecSet.Open(AFX_DAO_USE_DEFAULT_TYPE,"SELECT * FROM DemoTable",NULL);<br>  while(!RecSet.IsEOF())  // 有没有到表结尾<br>  {<br>    RecSet.GetFieldValue("Name",var);<br>    strName = (LPCSTR)var.pbstrVal;<br>    RecSet.GetFieldValue("Age",var);<br>    strAge = (LPCSTR)var.pbstrVal;<br>    m_AccessList.AddString( strName + " --> "+strAge );<br>    RecSet.MoveNext();<br>  }<br>  //关闭记录集及库<br>  RecSet.Close();<br>  db.Close();<br>}以上部分代码的具体实现的细节问题,可在下载实例代码后,仔细查看源码既可(内有详细注释)。

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号