在Windows Mobile上使用WINCE自带数据库

通过数据库,可以方便地存储和检索数据,极大地提高工作效率。在Windows CE .NET 4.2上,自带了一个数据库,具体我们可以参考MSDN上的网页:Microsoft Windows CE .NET 4.2 Database Reference。由于它最多只支持4种排序索引,这种数据库适合存储的数据量较小、数据结构相对简单的情况。它支持的数据类型包括2/4字节有/无符号整数、日期时间、Unicode字符串、CEBLOB、布尔和8字节有符号值。 数据库的主要操作包括以下几个方面: 装配数据库卷:BOOL CeMountDBVol( PCEGUID pceguid, LPWSTR lpszDBVol,DWORD dwFlags); 卸载数据库卷:BOOL CeUnmountDBVol(PCEGUID pceguid); 创建数据库:CEOID CeCreateDatabaseEx( PCEGUID pceguid, CEDBASEINFO *lpCEDBInfo); 打开数据库: HANDLE CeOpenDatabaseEx( PCEGUIDpceguid, PCEOIDpoid,LPWSTRlpszName, CEPROPIDpropid, DWORDdwFlags,CENOTIFYREQUEST *pReq); 写数据库: CEOID CeWriteRecordProps(HANDLEhDbase, CEOIDoidRecord, WORDcPropID, CEPROPVAL *rgPropVal), 读数据库: CEOID CeReadRecordPropsEx( HANDLE hDbase, DWORD dwFlags,LPWORD lpcPropID, CEPROPID *rgPropID, LPBYTE *lplpBuffer,LPDWORD lpcbBuffer, HANDLE hHeap); 删除记录:BOOL CeDeleteRecord(HANDLE hDatabase, CEOID oidRecord); 移动指针:CEOID CeSeekDatabaseEx(HANDLE hDatabase,DWORD dwSeekType, DWORD dwValue, WORD wNumVals, LPDWORD lpdwIndex); 使用方法 1.首先在主对话框的头文件中(这里我们建立了一个基于对话框的工程),我们来声明部分变量,用于存储数据库文件名和数据库名;定义一个数据库表结构;以及人员信息库的字段标识,我们通过MAKELONG宏来组合字段数据库类型和标识。相关代码如下: //定义数据库文件名 constLPTSTR DBFILENAME = _T("//My Documents//Workerinfo.db"); //定义数据库名 constLPTSTR DBTABLENAME = _T("Worker"); //定义员工数据库表结构 typedefstruct { TCHAR szID[10]; //子机ID号 TCHAR szName[20]; //员工姓名 TCHAR szWorkNum[10]; //工号 TCHAR szDepartment[20]; //部门号 }REC_WORKER,*PREC_WORKER; //定义子机ID号字段标志 #definePID_NO MAKELONG(CEVT_LPWSTR,1) //定义员工姓名字段标志 #definePID_NAME MAKELONG(CEVT_LPWSTR,2) //定义工号字段标志 #definePID_WorkNum MAKELONG(CEVT_LPWSTR,3) //定义员工部门字段标志 #definePID_Department MAKELONG(CEVT_LPWSTR,4) 2.为主对话框添加三个私有成员变量,用于存储库文件卷标识、数据库句柄以及数据库对象标识。代码片断如下: private: CEGUIDm_ceGuid;//存储数据库文件标志 HANDLEm_hDB; //存储数据库句柄 CEOIDm_ceOid; //存储数据库对象标志 3.在主对话框中给出装配数据库卷、卸载数据库卷、创建数据库、打开数据库、写数据库、读数据库、关闭数据库等等操作。这里就不罗列了。 实例工程是一个WM6平台上的WINCE数据库,基于对话框的应用程序,程序运行效果如下图所示: 图1:程序运行图 另外,我们可以在设备的“My Documents”目录下,找到“Workerinfo.db”文件,正如我们在头文件中所设置的路径,如下图2所示: 图2:数据库文件的路径
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值