Obt*_*bto 13 couchdb mapreduce views nosql
我有两个文件看起来有点像这样:
Doc
{
_id: AAA,
creator_id: ...,
data: ...
}
DataKey
{
_id: ...,
credits_left: 500,
times_used: 0,
data_id: AAA
}
Run Code Online (Sandbox Code Playgroud)
我想要做的是创建一个视图,允许我传递DataKey id(key = DataKey _id)并获取DataKey和Doc的信息.
我的尝试:
我首先尝试在Doc中嵌入DataKey并使用如下的map函数:
function (doc)
{
if (doc.type == "Doc")
{
var ids = [];
for (var i in doc.keys)
ids.push(doc.keys[i]._id);
emit(ids, doc);
}
}
Run Code Online (Sandbox Code Playgroud)
但我遇到了两个问题:
有谁有想法我怎么能做到这一点?如果有什么不清楚,请告诉我.
- - -编辑 - - -
我忘了提到在我的应用程序中我不知道Doc ID是什么,所以我需要能够搜索DataKey的ID.
Jas*_*ith 11
我想你想要的是什么
function (doc)
{
if (doc.type == "Doc")
{
emit([doc._id, 0], doc);
}
if(doc.type == "DataKey")
{
emit([doc.data_id, 1], doc);
}
}
Run Code Online (Sandbox Code Playgroud)
现在,查询视图,key=["AAA"]您将看到所有文档的列表.第一个将是真正的"Doc"文档.所有其余的将是"DataKey"文档,它们引用了第一个doc.
这是一种常见的技术,称为CouchDB视图排序规则.