DBM、GDBM与C语言跨平台代码研究

1.     简介

符合X/Open技术规范的UNIX版本自备了一个数据库。但这个数据库不符合ANSI标准的SQL技术规范(不支持SQL语句)。它只是一个存储检索数据的例程。

dbm、gdbm适合存储静态的,索引化的数据结构。它在创建数据项时非常慢,但检索数据项时非常快。

本文给出了dbm、gdbm各自的函数简要说明,最后给出了能够兼容DBM、GDBM两个不同数据库的C代码编写建议。

 

关键字:

DBM: UNIX系统的数据库,使用hash保存非结构化数据。它不支持SQL。

NDBM:新版本的DBM。操作函数加入了dbm_ 前缀。本文中如不作特殊声明,都使用的是ndbm。

GDBM:DBM的GNU版本。

跨平台C语言代码:具有跨平台特性的C语言代码。

2.     dbm

dbm使用两个数据文件,扩展名为”.pag”和”.dir”。但对数据库的操作返回值只有一个。注意:不要使用读写函数直接操作数据文件,应该使用dbm提供的数据操作函数访问数据。

2.1.    数据结构

数据、索引都使用以下结构保存:

       typedef struct {

        char *dptr;

        int   dsize;

      } datum;

 

数据库的访问结构(等同于FILE):

       typedef struct {int dummy[10];} DBM;

2.2.    函数简介

#include <ndbm.h>

 

 

DBM *dbm_open(const char *filename,

       int file_open_flags,                              

       mode_t file_mode                                

       );

成功时返回DMB类型指针,失败返回NULL

 

 

int dbm_store(DBM *database_descriptor,     

       datum key,                                    

       datum content,                                     

       int store_mode                                     

);

如果数据库打开方式为“dbm_insert”,而保存时该key对应的数据已经存在,则返回1;

如果出现其他错误,返回一个负数;

操作成功,返回0;

 

 

datum dbm_fetch(DBM *database_descreiptor,    

       datum key                                     

);

如果找到,则返回结构dptr和dsize分别赋值为数据指针和数据大小,如果没找到,则dptr赋值为NULL。

返回的datum结构中包含指向记录数据的指针,数据记录仍然在dbm内部某个存储区,如果需要,应把它拷贝到其他变量中。

 

 

void dbm_close(DBM *database_descriptor);

 

 

int dbm_delete(DBM *database_descriptor,datum key);

操作成功返回0;

 

int dbm_error(DBM *database_descriptor);    

没有错误返回0;

 

dbm_firstkey(),dbm_nextkey()一般成对使用,用于检索数据库中全部数据。

例如:

for(key=dbm_firstkey(db_ptr);key.dptr;key=dbm_nextkey(db_prt));

 

3.     gdbm

gdbm使用一个数据文件,与dbm不同。注意:不要使用读写函数直接操作数据文件,应该使用gdbm提供的数据操作函数访问数据。

3.1.    数据结构

数据、索引都使用以下结构保存(与dbm相同):

       typedef struct {

        char *dptr;

        int   dsize;

      } datum;

 

数据库的访问结构(等同于FILE):

       typedef struct {int dummy[10];} *GDBM_FILE;

 

3.2.    函数简介

#include <gdbm.h>

 

 

GDBM_FILE  *gdbm_open(

       char *name;       

       int block_size;          

             int read_write;                       /*可设置为:GDBM_READER、GDBM_WRITER、           

                                                                     GDBM_WRCREATER、GDBM_NE
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值