Ввод строки JSON в базу данных в C

106
10

Ниже мой код:

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

#define DATABASE "access.db"

/*printing the value corresponding to boolean, double, integer and strings*/
void print_json_value(json_object *jobj){
enum json_type type;
printf("type: ",type);
type = json_object_get_type(jobj); /*Getting the type of the json object*/
switch (type) {
case json_type_boolean: printf("json_type_boolean\n");
printf("value: %s\n", json_object_get_boolean(jobj)? "true": "false");
break;
case json_type_double: printf("json_type_double\n");
printf(" value: %lf\n", json_object_get_double(jobj));
break;
case json_type_int: printf("json_type_int\n");
printf(" value: %d\n", json_object_get_int(jobj));
break;
case json_type_string: printf("json_type_string\n");
printf(" value: %s\n", json_object_get_string(jobj));
break;
}

}

/*Parsing the json object*/
void json_parse(json_object * jobj) {
enum json_type type;
json_object_object_foreach(jobj, key, val) { /*Passing through every array element*/
printf("type: ",type);
type = json_object_get_type(val);
switch (type) {
case json_type_boolean:
case json_type_double:
case json_type_int:
case json_type_string: print_json_value(val);
db_json(&val);
break;
case json_type_object: printf("json_type_object\n");
jobj = json_object_object_get(jobj, key);
json_parse(jobj);
break;
case json_type_array: printf("type: json_type_array, ");
json_parse_array(jobj, key);
break;
}
}
}

int db_json(char *val) {

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->set_flags(dbp, DB_RECNUM)) != 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;
}

strncpy(s.data1, val, strlen(val)+1);

//printf("chk %\n",jvalue);

recno = 10;

memset(&key, 0, sizeof(key));
memset(&data, 0, sizeof(data));
//memset(&s, 0, sizeof(struct pearson_record));
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;
}

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;

exit(ret);
}

int main() {

char * string = "{\"Extracurricular\" : \"5,6,7,41,40,22,9,12,91,97\"}";
printf("JSON string: %s\n", string);
json_object * jobj = json_tokener_parse(string);
json_parse(jobj);
}

Когда я компилирую код, я вижу следующее предупреждение:

try.c: 81: 8: предупреждение: неявное объявление функции âdb_jsonâ

мой вывод: строка JSON: {"Внепрограммный": "5,6,7,41,40,22,9,12,91,97"} тип: тип: json_type_string значение: 5,6,7,41,40, 22,9,12,91,97 дБ: 10: сохраненный ключ. db: 10: извлеченный ключ: данные были p4È @4ȸ4È 500

В основном я хочу передать значение моей строки JSON в базу данных Berkeley DB. Я не могу найти, есть ли проблема передачи значения моей функции или есть что-то еще. Я уверен, что делаю небольшую проблему в указателях и функциях. Любая помощь будет оценена по достоинству. Заранее спасибо.

спросил(а) 2021-01-19T15:54:56+03:00 2 месяца, 3 недели назад
1
Решение
61

Одна из проблем заключается в том, что функция db_json принимает параметр char* в качестве параметра, но вызов ему представляется передачей адреса указателя на json_object. Я не знаком с функциями, но может быть, что вы должны передавать json_object_get_string(jobj) в качестве параметра db_json поскольку, как представляется, создается символьная строка представления данных JSON. Обратите внимание, что это лишь предположение из краткого взгляда на код; Я не знаком с типами.

ответил(а) 2021-01-19T15:54:56+03:00 2 месяца, 3 недели назад
Ваш ответ
Введите минимум 50 символов
Чтобы , пожалуйста,
Выберите тему жалобы:

Другая проблема