【发布时间】:2017-09-04 07:22:04
【问题描述】:
在我们的 couchbase 数据库中,我们有一个包含相对较大对象的存储桶。这些对象内部还有其他对象,比如说人。这应该是一个数组,但是由于某些原因,我们不得不将它创建为对象的对象,这就是它的样子:
{
"companyName": "company name",
"companyid": "11111-GUID-11111",
"people": {
"22222-GUID-22222": {
"peopleid": "22222-GUID-22222",
"name": "name1"
},
"33333-GUID-33333": {
"peopleid": "33333-GUID-33333",
"name": "name2"
},
"44444-GUID-44444": {
"peopleid": "44444-GUID-44444",
"name": "name3"
}
}
}
使用这种结构,我可以创建一个查询来获取“人”对象,使用如下查询:
SELECT c.*
FROM companies c
WHERE ANY v IN OBJECT_VALUES(c.people) SATISFIES v.peopleid = "22222-GUID-22222" END;
这种结构的问题是数据库响应的是整个公司对象,但是我只需要满足条件的“人”对象,不需要ID不是"22222-GUID-22222"的人。
有什么方法可以使用 couchbase 实现这一点吗?
【问题讨论】:
标签: sql database couchbase n1ql nosql