Windows Mobile上使用WINCE自带数据库

数据库 其他数据库 移动开发
本文将介绍如何在Windows Mobile上使用WINCE自带数据库,这个数据库比较简单,具备基本的数据库功能。支持的数据类型包括2/4字节有/无符号整数、日期时间、Unicode字符串、CEBLOB、布尔和8字节有符号值。

通过数据库,可以方便地存储和检索数据,极大地提高工作效率。在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宏来组合字段数据库类型和标识。相关代码如下:

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

 

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

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

TCHARszID[10];//子机ID号

TCHARszName[20]; //员工姓名

TCHAR szWorkNum[10]; //工号

TCHAR szDepartment[20]; //部门号

}REC_WORKER,*PREC_WORKER;

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

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

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

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

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

private:
CEGUID m_ceGuid; //存储数据库文件标志

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

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

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

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

 

图1:程序运行图

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

 

图2:数据库文件的路径

【编辑推荐】

  1. Windows Mobile 5.0中为开发人员提供的新功能
  2. 微软将推出Windows Mobile应用软件商店
  3. 使用Windows Mobile 5.0中的图片、视频和照相机
责任编辑:彭凡 来源: cnblogs
相关推荐

2009-06-30 10:48:49

WinCEWindows Mob

2022-01-19 07:32:11

数据库插件IDEA

2010-11-19 10:38:26

Oracle XE自带

2009-08-14 15:02:09

Visual Stud

2013-12-30 16:27:43

Windows画图工具

2024-11-12 14:48:10

2009-09-18 13:28:41

Mobile Sens

2021-02-19 18:05:23

数据库NoSQLIndexedDB

2010-08-03 14:40:05

DB2数据库

2011-03-08 08:49:55

MySQL优化单机

2020-08-25 08:00:18

Python开发数据库

2009-05-17 10:48:19

微软Windows Mob移动OS

2022-03-25 09:04:01

Mysql数据库

2012-05-10 11:34:04

Windows数据库

2017-06-19 08:13:00

Sequel ProMySQL数据库

2023-11-01 15:45:29

DBMPython

2009-12-07 17:42:07

Windows Mob

2009-12-15 15:31:47

2010-05-26 09:44:41

MySQL数据库使用

2019-08-15 07:00:54

SQLite数据库内存数据库
点赞
收藏

51CTO技术栈公众号