Помещение строки JSON в базу данных на C - PullRequest
0 голосов
/ 14 октября 2011

Ниже мой код:

#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 string: {"Extracurricular": "5,6,7,41,40,22,9,12,91,97"} type: type: json_type_string значение: 5,6, 7,41,40,22,9,12,91,97 дБ: 10: ключ сохранен.db: 10: ключ получен: данные были p4È @ 4ȸ4È 500

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

1 Ответ

1 голос
/ 14 октября 2011

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

...