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 读取数据失败的主要内容,如果未能解决你的问题,请参考以下文章

Berkeley DB:锁定记录而不读取它

Java Berkeley DB 是不是有并发读取的上限?

Java Berkeley DB 读取性能与 100M 文档

如何使用 Python 读取 Berkeley DB 文件?

使用 Berkeley DB、C++ STL 接口进行批量读取

从 Java 中的另一个类访问 berkeley db