前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在Windows Mobile上使用WINCE自带数据库

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

作者头像
ShiJiong
发布2018-01-11 12:07:31
1.6K0
发布2018-01-11 12:07:31
举报
文章被收录于专栏:施炯的IoT开发专栏

    通过数据库,可以方便地存储和检索数据,极大地提高工作效率。在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( PCEGUID pceguid, PCEOID poid,LPWSTR lpszName, CEPROPID propid, DWORD dwFlags,CENOTIFYREQUEST *pReq);

数据库: CEOID CeWriteRecordProps(HANDLE hDbase, CEOID oidRecord, WORD cPropID, 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宏来组合字段数据库类型和标识。相关代码如下:

代码语言:js
复制

Code
//定义数据库文件名
const LPTSTR DBFILENAME = _T("\\My Documents\\Workerinfo.db");

//定义数据库名
const LPTSTR DBTABLENAME = _T("Worker");

//定义员工数据库表结构
typedef struct
{

     TCHAR   szID[10];            //子机ID号

     TCHAR   szName[20];          //员工姓名

     TCHAR    szWorkNum[10];       //工号

     TCHAR    szDepartment[20];    //部门号

}REC_WORKER,*PREC_WORKER;
 

//定义子机ID号字段标志
#define PID_NO           MAKELONG(CEVT_LPWSTR,1)

//定义员工姓名字段标志
#define PID_NAME         MAKELONG(CEVT_LPWSTR,2)

//定义工号字段标志
#define PID_WorkNum      MAKELONG(CEVT_LPWSTR,3)

//定义员工部门字段标志
#define PID_Department   MAKELONG(CEVT_LPWSTR,4)

2.为主对话框添加三个私有成员变量,用于存储库文件卷标识、数据库句柄以及数据库对象标识。代码片断如下:

代码语言:js
复制
private:
        CEGUID m_ceGuid; //存储数据库文件标志

         HANDLE m_hDB;  //存储数据库句柄

         CEOID m_ceOid;   //存储数据库对象标志

3.在主对话框中给出装配数据库卷、卸载数据库卷、创建数据库、打开数据库、写数据库、读数据库、关闭数据库等等操作。这里就不罗列了。

实例工程是一个WM6平台上的WINCE数据库,基于对话框的应用程序,程序运行效果如下图所示:

图1:程序运行图

另外,我们可以在设备的“My Documents”目录下,找到“Workerinfo.db”文件,正如我们在头文件中所设置的路径,如下图2所示:

图2:数据库文件的路径

参考链接:

Microsoft Windows CE .NET 4.2 Database Reference

代码下载:CEDBSample.rar

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2009-04-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档