Embedded 版 (精华区)

发信人: bage (铁八哥), 信区: Embedded_system
标  题: Windows CE平台上的数据库编程
发信站: 哈工大紫丁香 (2001年10月05日18:34:52 星期五), 站内信件

  随着掌上电脑的迅速崛起,微软推出的运行在掌上电脑上的操作系统Windows CE越
来越引人瞩目。
  Windows CE包括一个Win32 API子集,一个适宜于静态、动态内存存储的文件系统等
。根据需要,还增加了一些Windows所没有的特性,增加了一些新的API(包括一些新的数据
库API)。其中数据库被定位在对象存储(Object Store)中。对象存储是掌上电脑内存的
一部分,是操作系统分配来存储永久文件、注册表、Windows CE 数据库的。掌上电脑剩
余的内存是应用程序内存,供应用程序使用。
  Windows CE中用来操作数据库的函数有:打开数据库CeOpenDatabase(); 关闭数据库
CloseHandle(); 删除纪录CeDeleteRecord等。
  Windows CE上数据库的一些附加特性也是很有意思的,如数据库支持“time stamp
s”,这个特性让开发者可以测试自上次读数据后是否有别的程序修改了数据。
  下面让我们详细介绍Windows CE上的数据库编程(开发工具:VC 5.0,WindowsCE Too
lKit for VC 5.0)。
   基本数据库操作
  1.创建数据库
void CMyDB::CreateDatabase()
  {
   CCeDBDatabase db;
   // 检查数据库是否存在
   if(!CCeDBDatabase::Exists(_T("My Database")))
   {
   file://如果数据库不存在,就创建它
   db.Create(_T("My Database"));
   }
  }
  2.打开数据库
CCeDBDatabase db;
db.Open(_T(″My Database″));
  
  3.删除数据库
CCeDBDatabase db;
if (db.Open(_T(″My Database″)))
 db.Delete();
  
  4.关闭数据库
CCeDBDatabase db;
db.Open(_T(″My Database″));
db.Close();
  
  向数据库中加入纪录
  这里我向大家介绍另两个数据库类:CCeDBRecord,CCeDBProp。
  创建数据库时,我们可以同时定义字段,然后设置纪录变量的各字段值,最后将记录加
入到数据库中。
// Create database
   const DWORD DB_IDENT_ID = 11111;
   const WORD PROP_NAME=101,PROP_AGE=102,PROP_GENDER=103;
   CCeDBDatabase db ;
   CEOID poid;
   CCeDBProp dbprops[3] = {
   CCeDBProp(CCeDBProp::Type_String,PROP_NAME,CCeDBProp::Sort_Ascending),
   CCeDBProp(CCeDBProp::Type_UShort,PROP_AGE,CCeDBProp::Sort_Descending),
   CCeDBProp(CCeDBProp::Type_UShort,PROP_GENDER,CCeDBProp::Sort_UnknownFir
st)
   };
   if(!(poid = db.Create((_T("My DB"),DB_IDENT_ID,3,dbprops)))
   return FALSE;
   if(!db.Open(poid)) return FALSE;
   // Add records
   CCeDBRecord rec;
   CCeDBProp props[3];
   props[0] = CCeDBProp(_T("LiMing"),PROP_NAME);
   props[1] = CCeDBProp((USHORT)20, PROP_AGE);
   props[2] = CCeDBProp((USHORT)'M',PROP_GENDER);
   rec.AddProps(props,3);
   if(!db.AddRecord(&rec)) return FALSE;
  
  从数据库中检索纪录
  我们可以通过调用CCeDBDatabase::GetNumRecords()获取纪录数。通过CCeDBDatab
ase::GetCurrRecord()获取每个纪录的指针。
BOOL bPrev = pdb-〉m_bAutoSeekNext;
   pdb-〉m_bAutoSeekNext = TRUE;
   pdb-〉SeekFirst();
   while(pdb-〉ReadCurrRecord(&rec))
   MyPrintRecord(&rec);//处理数据(显示记录)
   pdb-〉m_bAutoSeekNext = bPrev;
  通过调用CCeDBRecord::GetPropFromIdent()获取每个字段值。
   pPropName=prec-〉GetPropFromIdent(PROP_NAME);
   LPWSTR strName=pPropName-〉GetString();
  除了可以遍历数据库纪录外,还可按条件查找纪录,如:查找具有指定属性的记录。
  CCeDBProp prop;
   ....//设置待查找纪录的属性
   db.SeekFirstEqual(&prop);
   从数据库中删除纪录
  file://先查找指定纪录
  db.DeleteCurrRecord();
   修改数据库中纪录
   CCeDBRecord rec;
   ....//查找待修改的记录
   ....//修改记录的属性

--
           ooooO    Ooooo      *********************************
           (    )   (    )     #    大肚能容,容天下难容之事    #  
            \  (     )  /      #    开口便笑,笑世间可笑之人    #
             \  )   (  /       *********************************
              ~~     ~~

※ 来源:·哈工大紫丁香 bbs.hit.edu.cn·[FROM: bage.hit.edu.cn]
[百宝箱] [返回首页] [上级目录] [根目录] [返回顶部] [刷新] [返回]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:2.945毫秒