Berkeley DB 读取数据失败
Berkeley DB Reading a data fail
出于实验原因,我正在研究 Berkeley DB。但是我有一个关于从数据库读取文件的问题。
当程序像
创建数据库
打开
写入
阅读
关闭
执行完全没有问题
但是当我将数据写入数据库文件并关闭它,然后再次打开它并尝试读取时,它会抛出错误。代码中没有编译错误或任何警告。在 dbRead() 方法中,当程序进入 db->get (...) 部分时,它会抛出类似 ; 的错误。
BDB1001 illegal record number size
get error ( 22 ): Invalid argument
我的写入数据库的代码是;
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;
}
我从数据库读取的代码是(程序抛出错误的部分在这里。)
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 的 return 是 12。而 dbRead 的 return 是 5。我知道那一点是 db->get 方法,但我找不到真正的东西。
我找不到问题。但是当我使用 DB_BTREE 而不是 DB_RECNO 时,它工作得很好。
出于实验原因,我正在研究 Berkeley DB。但是我有一个关于从数据库读取文件的问题。
当程序像
创建数据库
打开
写入
阅读
关闭
执行完全没有问题
但是当我将数据写入数据库文件并关闭它,然后再次打开它并尝试读取时,它会抛出错误。代码中没有编译错误或任何警告。在 dbRead() 方法中,当程序进入 db->get (...) 部分时,它会抛出类似 ; 的错误。
BDB1001 illegal record number size
get error ( 22 ): Invalid argument
我的写入数据库的代码是;
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;
}
我从数据库读取的代码是(程序抛出错误的部分在这里。)
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 的 return 是 12。而 dbRead 的 return 是 5。我知道那一点是 db->get 方法,但我找不到真正的东西。
我找不到问题。但是当我使用 DB_BTREE 而不是 DB_RECNO 时,它工作得很好。