none
eVC中利用ADOCE访问Access数据库 RRS feed

  • 常规讨论

  • 我刚刚开始开发PPC应用程序,考虑到自己对于C++语言比较熟悉,于是选择了eVC4.0 + Pocket PC 2003 SDK开发环境。感到欣喜的是,很多东西和VC++6.0几乎一样,上手也很快。但是在数据库发开方面,碰到了困难。

    一开始,我选择了WinCE自带的数据库。实现起来也自然是非常简单。可是,到后来,发现WinCE自带的数据库和PC中的数据库同步存在一定的困难。首先,ActiveSync不支持;难道要自己写转换接口,好像有点行不通。于是,郁闷,一直在网上找相关资料。用Google搜,用baidu也搜。

    最后,在zuilangblog上,找到了希望的曙光。他的这篇名为“艰苦的过程:在evc中使用ADOCE的前期准备”的文章,为我指明了一条道路,可以用ADOCE来访问Access数据库。而Access数据库在PC上是比较通用的数据库类型,SQL Server 2000可以将其中的一些数据表转成后缀为.mdbAccess可以访问的数据库。

    在该blog的回帖中,又有了意外的发现,书童Macintosh 2005-12-27 11:22:32回复的帖子中,指明了EVC4.0+ADOCE3.1访问Access数据库的具体方法。看完帖子后,激动不已,马上着手实践。按照Macintosh的提示,一步一步进行下来,还是比较顺利。其实,Macintosh已经说的非常清楚了。我在这里只是做了验证性的工作而已。


    一、资源需求

     

     

    1.       去微软网站下载ADOCE3.1的安装包,链接为:

    http://www.microsoft.com/downloads/info.aspx?na=90&p=&SrcDisplayLang=en&SrcCategoryId=&SrcFamilyId=929bb147-281c-4d6e-a727-67271075fadb&u=http%3a%2f%2fdownload.microsoft.com%2fdownload%2fado%2fCE-PB%2f3.1%2fWCE%2fEN-US%2fadocepbzip.exe

    名字非常的繁琐,幸好只是一个链接,直接点击就OK了。

    2.       VoAdoVOS公司做的一个使用比较方便的ADOCONNECTIONADORECOEDSET类,下载的链接为:

    http://www.voscorp.com/products/developer/winmobile/voado/voado.zip


    二、文件的生成、修改和下载

    1.         adoce31.hadocec31.h文件的生成

    在微软的adocepbzip安装包的adocepb\setup\Data Access 3.1\Program Files \DataAccess31 \INCLUDE目录下,有这样两个文件:adoce31.idladocec31.idl。在命令行状态下,进入该目录,然后执行midl adoce31.idlmidl adocec31.idl即可生成adoce31.hadocec31.h文件。注意,一定要进到adocepb\setup\Data Access 3.1\Program Files \DataAccess31 \INCLUDE目录下,不然执行midl adoce31.idlmidl adocec31.idl会不成功,提示有可能是说'midl' 不是内部或外部命令,也不是可运行的程序或批处理文件。

    2.         VoAdo文件的修改

    根据adoce31.hadocec31.h文件,我们必须把下载的VoAdo进行适当的修改,将其中ado**30.h都改为ado**31.h

    vorecordset.cpp文件中,将TCHAR* CVORecordset::g_ProgID = TEXT("ADOCE.Recordset.3.0")改为TCHAR*         CVORecordset::g_ProgID = TEXT("ADOCE.Recordset.3.1")

    3.         下载.dllregsvrce.exe到目标设备

    adocepb\setup\DataAccess3.1\Program Files \DataAccess31 \DEVICE \ARM \SA1100 \CE \RETAIL下的.dll文件复制到PPC/Windows目录下。

    Program Files\Microsoft eMbedded C++ 4.0\EVC\WCE400\TARGET\ARMV4文件夹下的regsvrce.exe文件复制到设备中和数据库程序同一个文件夹下。

     

    三、编程中注意事项

    1.         dll的注册

    在我们的数据库程序中要使用VOADO的话,首先必须注册这些DLL,例如,在OnInitDialog()函数中,可以使用下面的语句来进行注册:

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\adoce31.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\Adoxce31.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\Adocedb31.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\Adoceoledb31.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\Msdaer.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\Msdaeren.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\msdadc.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    CreateProcess(_T("\RegSvrCe"),_T("/s \Windows\\msdaosp.dll"),NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);

    2.         文件的包括

    将之前我们修改完成的adoce31.hadocec31.h文件加入到我们的工程之中。

    3.         目标设备中文件的放置

    按照前面的要求,我们必须要把编译生成的可执行文件.exe、操作的数据库文件和regsvrce.exe放置在同一文件夹下,不然,数据库就无法访问。

    4.         数据库操作语句

    之前,我是按照标准SQL语言来进行操作,发现不行。例如,我要从名为Account的数据库的PersonInfo表中选取name字段为“张明”的所有信息,按照标准的SQL语言,应该是这样子的:“select * from [Account].[dbo].[ PersonInfo] where  [Account].[dbo].[ PersonInfo].[name] = ‘张明”,从实际的调试情况来看,如果按照这种语法的话,是无法正确open的。后来,自己胡乱猜测,试验出来了,可以执行的语句如下:“select * from PersonInfo where name = ‘张明”,当然,这只是我自己胡乱猜测的,不知道正确的语法应该如何,这还有待查证。
    2009年6月26日 6:00