Berkeley DB读取数据失败

时间:2015-12-17 12:26:24

标签: c database berkeley-db

出于不同的原因,我正在研究伯克利数据库。但我有一个从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方法但我找不到真正的东西。

1 个答案:

答案 0 :(得分:0)

我找不到问题。但是当我使用DB_BTREE而不是DB_RECNO时,它工作得很完美。