CouchDB "Join" два документа
У меня есть два документа, которые выглядят примерно так:
Doc
{
_id: AAA,
creator_id: ...,
data: ...
}
DataKey
{
_id: ...,
credits_left: 500,
times_used: 0,
data_id: AAA
}
Я хочу создать представление, которое позволило бы мне передать идентификатор DataKey (key=DataKey _id) и получить информацию как DataKey, так и документа.
Моя попытка:
Сначала я попытался встроить DataKey в Doc и использовал функцию карты следующим образом:
function (doc)
{
if (doc.type == "Doc")
{
var ids = [];
for (var i in doc.keys)
ids.push(doc.keys[i]._id);
emit(ids, doc);
}
}
Но я столкнулся с двумя проблемами:
- Для каждого документа может быть несколько DataKey, поэтому использование startkey=[idhere...] и endkey=[idhere..., {}] не сработало (работало только в том случае, если ключ оказался первым в массиве).
- Все ключи данных должны быть уникальными, и я бы предпочел не создавать отдельный документ, такой как {_id = datakey}, чтобы зарезервировать ключ.
У кого-нибудь есть идеи, как мне это сделать? Дайте мне знать, если что-то неясно.
-----РЕДАКТИРОВАТЬ-----
Я забыл упомянуть, что в моем приложении я не знаю, что такое идентификатор документа, поэтому мне нужно иметь возможность поиска по идентификатору DataKey.
1 ответ
Я думаю, что вы хотите
function (doc)
{
if (doc.type == "Doc")
{
emit([doc._id, 0], doc);
}
if(doc.type == "DataKey")
{
emit([doc.data_id, 1], doc);
}
}
Теперь запросите представление с помощью key=["AAA"]
и вы увидите список всех документов. Первым будет настоящий документ "Док". Все остальное будет документами "DataKey", которые ссылаются на первый документ.
Это распространенный метод, называемый CouchDB.