如何在sqlite3中将json数组索引设置为绑定参数?

时间:2017-03-12 00:36:02

标签: c json sqlite sqlite-json1

我在 SQLite3 json1 扩展程序中使用 C-API 。在数据库中,整数列表存储为 json_array 。我想使用 json_extract 函数从json_array创建一个C整数数组。我通过递增SQL语句中的索引来循环json数组中的每个值。例如,请考虑:

CREATE TABLE mytable ( label INTEGER PRIMARY KEY, list TEXT);
INSERT INTO mytable VALUES ( 1, json(json_array(1,2,3)) ); 

SELECT json_extract( list, '$[index]' ) FROM mytable WHERE label == 1;
---Example: the result for index=0 is the integer: 1

在C程序中,我正在创建一个字符串来表示命令的{strong>单引号部分'$[index]',作为绑定参数,如下面的代码段所示。

可以或应该避免使用sprintf来设置索引吗?或者,这是一个可以接受的解决方案吗?

char *sql = "select json_extract(list, ?) from mytable where label == 1";
char *index_param = (char *)malloc(80);

// OTHER STUFF: prepare sql stmt, etc, etc...

for (int i=0; i<n; i++) {  /* n is the number of values in the json list */

    /* Is sprintf the best thing to do here? */
    index_length = sprintf(index_param, "$[%d]", i);

    sqlite3_bind_text(stmt, 1, index_param, index_length+1, SQLITE_STATIC);
    result = sqlite3_step(stmt);
    values[i] = sqlite3_column_int(stmt, 0);
    sqlite3_reset(stmt);
}

1 个答案:

答案 0 :(得分:0)

您可以在SQL中构造路径,以便只有一个整数参数:

SELECT json_extract(list, '$[' || ? || ']') FROM ...

但最好直接使用json_each()函数读取数组值:

const char *sql = "SELECT value FROM MyTable, json_each(MyTable.list) WHERE ...";
// prepare ...
for (;;) {
    rc = sqlite3_step(stmt);
    if (rc != SQLITE_ROW)
        break;
    values[i++] = sqlite3_column_int(stmt, 0);
}