Не удалось получить значения из Беркли DB в C - PullRequest
0 голосов
/ 11 ноября 2011

У меня есть два отдельных кода, один для вставки данных и один для извлечения данных в БД Berkeley с использованием C. Моя проблема в том, что я могу видеть, что мои данные хранятся, и когда я делаю db-> получить сразу после дб-> поставить, я вижу значения. Но когда я пытаюсь сделать db-> get через отдельный код, у меня возникают проблемы, я получаю ошибку db-> get: DB_NOTFOUND, когда я не использую функцию удаления. Не уверен, где ошибка

Вставка кода данных: (я передаю в него строку из другой функции)

int db_json(char *json) {

    typedef struct {                             
        char data1[500];    
    } pearson_record;

    pearson_record s;
    int i =0;
    DB *dbp;
    DBT key, data;
    int ret, t_ret;
    int recno;

    if ((ret = db_create(&dbp, NULL, 0)) != 0) {
        fprintf(stderr, "db_create: %s\n", db_strerror(ret));
        exit (1);
    }

    if ((ret = dbp->open(dbp, NULL, DATABASE, NULL, DB_BTREE, DB_CREATE, 0664)) != 0) {
        dbp->err(dbp, ret, "%s", DATABASE);
        goto err;
    }

    printf("data: %s\n",json);
    strncpy(s.data1, json, strlen(json)+1);

    recno = 1;

    memset(&key, 0, sizeof(key));
    memset(&data, 0, sizeof(data));

    key.data = &recno;
    key.size = sizeof(recno);
    data.data = &s;
    data.size = sizeof(s);

    if ((ret = dbp->put(dbp, NULL, &key,&data,0)) == 0)
        printf("db: %d: key stored.\n", *(int *)key.data);
    else
    {
        dbp->err(dbp, ret, "DB->put");
        goto err;
    }

    err:    
        if ((t_ret = dbp->close(dbp, 0)) != 0 && ret == 0)
            ret = t_ret; 

    return 0;
}

Получение кода данных:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <json/json.h>
#include <curl/curl.h>
#include <sys/types.h>
#include <db.h>

#define  DATABASE "mydata.db"

int main()
{
    typedef struct {                            
        char data1[500];
    } pearson_record;

    pearson_record s;
    int i =0;
    DB *dbp;
    DBT key, data;
    int ret, t_ret;
    int recno;               

    if ((ret = db_create(&dbp, NULL, 0)) != 0) {
        fprintf(stderr, "db_create: %s\n", db_strerror(ret));
        exit (1);
    }   

    if ((ret = dbp->open(dbp, NULL, DATABASE, NULL, DB_BTREE, DB_CREATE, 0664)) != 0) {
        dbp->err(dbp, ret, "%s", DATABASE);
        goto err;
    }

    memset(&key, 0, sizeof(key));
    memset(&data, 0, sizeof(data));

    pearson_record *ppr;

    if ((ret = dbp->get(dbp, NULL, &key, &data, 0)) == 0) {   
        ppr = (pearson_record *) data.data;
        printf("db: %d: key retrieved: data was %s %d\n",
             *(int *)key.data, ppr->data1, data.size);
     }
     else {
         dbp->err(dbp, ret, "DB->get");         
    }
    goto err;

    err:    
        if ((t_ret = dbp->close(dbp, 0)) != 0 && ret == 0)
            ret = t_ret; 

    return 0;
}

1 Ответ

0 голосов
/ 21 декабря 2011

Чтобы использовать DB-> get (), вам нужно знать точный ключ записи, которую вы хотите получить.В вашем примере вам нужно установить recno = 1, а затем настроить ключ DBT, чтобы он указывал на него, прежде чем вызывать DB-> get ().

В вероятном случае, когда вы не знаете,ключ, который вы хотите, это DB-> cursor () и DBcursor-> get ().Вы можете открыть курсор для базы данных с помощью DB-> cursor (), а затем зациклить вызов DBcursor-> get (curs, & key, & data, DB_NEXT).Это вернет каждую запись в базе данных, начиная с начала.

В разделе «Извлечение записей с курсором» в Справочнике по программированию BDB приведен отличный пример:

http://docs.oracle.com/cd/E17076_02/html/programmer_reference/am_cursor.html#am_curget

...