我在资源数据存储区中定义了一个名为“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中的已知问题/错误吗?
答案 0 :(得分:4)
谢谢!你找到了一个bug。我在https://github.com/ckan/ckan/pull/1776修复了它并发送了拉取请求。这将由另一个核心开发人员审核,并将很快合并。
如果您有时间,如果您可以测试该分支以确认它可以解决此问题,那将非常有用。如果您这样做,请在拉取请求中添加评论。
干杯!