gpt4 book ai didi

c - 无法用 C 语言从 Berkeley DB 检索值

转载 作者:行者123 更新时间:2023-11-30 18:03:41 24 4
gpt4 key购买 nike

我有两个单独的代码,一个用于插入数据,另一个用于使用 C 检索 Berkeley DB 中的数据。我的问题是我能够看到我的数据已存储,并且当我执行 db->get 之后立即执行db->put,我看到了值。但是当我尝试通过单独的代码执行 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;
}

最佳答案

要使用 DB->get(),您需要知道要检索的记录的确切键。在您的示例中,您必须设置 recno = 1,然后在调用 DB->get() 之前将 key DBT 设置为指向它。

在您可能不知道 key 的情况下,您想要的是 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

关于c - 无法用 C 语言从 Berkeley DB 检索值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8091556/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com