出于不同的原因,我正在研究伯克利数据库。但我有一个从DB读取文件的问题。
当程序如
创建数据库
开放
写
阅读
关闭
在执行中根本没有问题。
但是当我将数据写入db文件并关闭它,然后再次打开并尝试读取时,它会抛出错误。代码中没有编译错误或任何警告。在dbRead()方法中,当程序进入db-> get(...)部分时,它会抛出一个错误,如;
BDB1001 illegal record number size
get error ( 22 ): Invalid argument
写入DB的代码是;
int dbWrite()
{
DB *db;
DBT key, data;
int ret;
ret = db_create( &db, NULL, 0 );
if( ret != 0 )
{
db->err( db, ret, "db_create error ( %d )", ret );
return 1;
}
ret = db->set_re_source( db, "db" );
if( ret != 0 )
{
db->err( db, ret, "set_re_source error ( %d )", ret );
return 2;
}
ret = db->open( db, NULL, "db", NULL, DB_RECNO, DB_CREATE, 0 );
if( ret != 0 )
{
db->err( db, ret, "open error ( %d )", ret );
return 3;
}
memset( &key, 0, sizeof( key ) );
key.data = "key";
key.size = strlen( "key" );
memset( &data, 0, sizeof( data ) );
data.data = "data";
data.size = strlen( "data" );
ret = db->put( db, NULL, &key, &data, DB_APPEND );
if( ret != 0 )
{
db->err( db, ret, "put error ( %d )", ret );
return 4;
}
ret = db->close( db, 0 );
if( ret != 0 )
{
fprintf( stderr, "close error ( %d )", ret );
/* db->err( db, ret, "" ); */
return 7;
}
return 12;
}
从DB读取的代码是(程序引发错误的部分在这里。)
int dbRead(){
DB *db;
DBT data;
int ret;
ret = db_create( &db, NULL, 0 );
if( ret != 0 )
{
db->err( db, ret, "db_create error ( %d )", ret );
return 1;
}
ret = db->set_re_source( db, "db" );
if( ret != 0 )
{
db->err( db, ret, "set_re_source error ( %d )", ret );
return 2;
}
ret = db->open( db, NULL, "db", NULL, DB_RECNO, DB_CREATE, 0 );
if( ret != 0 )
{
db->err( db, ret, "open error ( %d )", ret );
return 3;
}
memset( &key, 0, sizeof( key ) );
key.data = "key";
key.size = strlen( "key" );
memset( &data, 0, sizeof( data ) );
data.size = 255;
ret = db->get( db, NULL, &key, &data, 0 );
if( ret != 0 )
{
db->err( db, ret, "get error ( %d )", ret );
return 5;
}
printf( "OK \n" );
printf( "Data: %s \n", data.data );
return 11;
};
另外,dbWrite的返回值是12.而dbRead的返回值是5.我知道这点是db-> get方法但我找不到真正的东西。
答案 0 :(得分:0)
我找不到问题。但是当我使用DB_BTREE而不是DB_RECNO时,它工作得很完美。