在数据存储区中的JSON类型字段中插入空数组

时间:2014-06-13 13:54:33

标签: arrays json datastore ckan

我在资源数据存储区中定义了一个名为“value”的字段,其类型为JSON(在其他一些字段中)。如果我使用简单值或非空数组运行upserts,则一切正常:

POST http://host/api/3/action/datastore_upsert
{
   "resource_id": "...",
   "records": [
                 { "value": [ "1", "2" ] }
              ],
   "method": "insert",
   "force": "True"
}

POST http://host/api/3/action/datastore_upsert
{
   "resource_id": "...",
   "records": [
                 { "value": "23" }
              ],
   "method": "insert",
   "force": "True"
}

但是,如果我使用空数组

POST http://host/api/3/action/datastore_upsert
{
   "resource_id": "...",
   "records": [
                 { "value": [ ] }
              ],
   "method": "insert",
   "force": "True"
}

我收到以下错误:

{
    ...
    "success": false,
    "error": {
        "info": {
            "orig": [
                "malformed record literal: \"{}\"\nLINE 2:             VALUES (NULL, NULL, NULL, NULL, '{}', NULL, to_t...\n                                                    ^\nDETAIL:  Missing left parenthesis.\n"
            ]
        },
        "__type": "Validation Error",
        "data": "(DataError) malformed record literal: \"{}\"\nLINE 2:             VALUES (NULL, NULL, NULL, NULL, '{}', NULL, to_t...\n                                                    ^\nDETAIL:  Missing left parenthesis.\n"
    }
}

鉴于[ ]是JSON中的有效元素,我想知道为什么会发生这种错误。这是CKAN数据存储API中的已知问题/错误吗?

1 个答案:

答案 0 :(得分:4)

谢谢!你找到了一个bug。我在https://github.com/ckan/ckan/pull/1776修复了它并发送了拉取请求。这将由另一个核心开发人员审核,并将很快合并。

如果您有时间,如果您可以测试该分支以确认它可以解决此问题,那将非常有用。如果您这样做,请在拉取请求中添加评论。

干杯!