Berkeley DB 读取数据失败
Posted
技术标签:
【中文标题】Berkeley DB 读取数据失败【英文标题】:Berkeley DB Reading a data fail 【发布时间】:2015-12-17 12:26:24 【问题描述】:出于实验原因,我正在研究 Berkeley DB。但我有一个关于从数据库读取文件的问题。
当程序像
创建数据库
打开
写
阅读
关闭
在执行中完全没有问题。
但是当我将数据写入 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 的返回值为 12。dbRead 的返回值为 5。我知道这一点是 db->get 方法,但我找不到真正的东西。
【问题讨论】:
您是否检查过此问题“导致该错误的最常见原因是您尝试使用较新版本的 Berkeley DB 库打开较早的 Berkeley DB 文件。” (例如见docs.python.org/2/faq/…?) 我只是在读取数据库之前创建数据库。因此,您所说的情况对于这个问题是不可能的。不管怎么说,还是要谢谢你。多亏了你,我学到了一些有用的东西:) 我只是尝试删除而不是读取。它给出了同样的错误。我认为问题出在“关键”方面。 【参考方案1】:我找不到问题。但是当我使用 DB_BTREE 而不是 DB_RECNO 时,它工作得很好。
【讨论】:
以上是关于Berkeley DB 读取数据失败的主要内容,如果未能解决你的问题,请参考以下文章
Java Berkeley DB 读取性能与 100M 文档
如何使用 Python 读取 Berkeley DB 文件?