在 Couchbase 中更新高度嵌套的文档
Updating a Highly Nested Document in Couchbase
我有一个包含多个层次结构的文档。像这样:
{
"id": "520707438",
"pageURIHash": "3988665684",
"children": [],
"parentId": null,
"content": "Here is a parent comment"
}
children数组可能有其他child评论如JSONobjects,每个child依次可能有其他child仁。这样就形成了一个高度嵌套的结构。
现在,假设我想将 child 评论添加到 ID
作为 123456745
的评论中。我假设我知道 root-level 注释(这样我就可以在我的 N1ql
查询中使用 USE KEYS
子句)。如何提取与具有该特定 ID 的评论相对应的 children
数组并向其附加新评论?我可以使用 sub-document API 但它需要我知道路径,在这种情况下,我不知道它。
我做了一些研究并提出了这个查询:
"UPDATE default d use keys \"" + comment.getRootCommentId()
+ "\" SET (??? How do I get the existing array and append to it) FOR p WITHIN d.children WHEN p.id = \"" + comment.getId() + "\" END";
非常感谢!!
这应该可以满足您的要求:
update default d use keys "foo"
SET p.children = ARRAY_APPEND(p.children, {
"id": "20202020",
"pageURIHash": "99999",
"children": [],
"parentId": null,
"content": "New Stuff"
}) FOR p WITHIN d.children WHEN p.id = "520707440" END
我有一个包含多个层次结构的文档。像这样:
{
"id": "520707438",
"pageURIHash": "3988665684",
"children": [],
"parentId": null,
"content": "Here is a parent comment"
}
children数组可能有其他child评论如JSONobjects,每个child依次可能有其他child仁。这样就形成了一个高度嵌套的结构。
现在,假设我想将 child 评论添加到 ID
作为 123456745
的评论中。我假设我知道 root-level 注释(这样我就可以在我的 N1ql
查询中使用 USE KEYS
子句)。如何提取与具有该特定 ID 的评论相对应的 children
数组并向其附加新评论?我可以使用 sub-document API 但它需要我知道路径,在这种情况下,我不知道它。
我做了一些研究并提出了这个查询:
"UPDATE default d use keys \"" + comment.getRootCommentId()
+ "\" SET (??? How do I get the existing array and append to it) FOR p WITHIN d.children WHEN p.id = \"" + comment.getId() + "\" END";
非常感谢!!
这应该可以满足您的要求:
update default d use keys "foo"
SET p.children = ARRAY_APPEND(p.children, {
"id": "20202020",
"pageURIHash": "99999",
"children": [],
"parentId": null,
"content": "New Stuff"
}) FOR p WITHIN d.children WHEN p.id = "520707440" END