我们假设我们有两个集合,一个用户集合和一个项目集合。
用户集合,每个用户文档存储用户的购买产品ID。
{
"id" : "UserA",
"PurchasedProductId" : ["ProductId1", ... "ProductIdNN"]
}
项目集合,每个Item文档存储产品信息。
{
"Id" : "ProductId1"
}
我希望查询将返回项目集合的前10项,按上次更新时间排序,另外,如果用户之前已经购买了该项目,则查询应跳过用户购买的项目并返回未购买的项目只有项目。
在MsSQL中我们可以简单地不存在,我们如何在documentDB中有效地做到这一点?
我们如何在documentDB中做到这一点?
我可以想象当然我们可以像
一样通过SELECT * WHERE (c.id != id1 && c.id != id2 && ..... c.id != idNNNN) LIMIT 10
但实际上,如果每个用户购买了500多件商品,这是否有效?
有效的方法是什么?
答案 0 :(得分:0)
到目前为止,我的research,Exist
和NOT Exists
在cosmos数据库查询中不受支持。所以,我建议你使用存储过程来获得你想要的结果。
示例存储过程:
function sample(alreadyPurchaseIdsArray) {
var collection = getContext().getCollection();
//var alreadyPurchaseIdsArray = ["1","2","3"]
var isAccepted = collection.queryDocuments(
collection.getSelfLink(),
'SELECT top 10 c.id FROM c ',
function (err, feed, options) {
if (err) throw err;
if (!feed || !feed.length) {
var response = getContext().getResponse();
response.setBody('no docs found');
}else {
var response = getContext().getResponse();
var returnResult = [];
for(var i = 0;i<feed.length;i++){
if(alreadyPurchaseIdsArray.indexOf(feed[i].id) == -1)
returnResult.push(feed[i]);
getContext().getResponse().setBody(returnResult);
}
}
});
if (!isAccepted) throw new Error('The query was not accepted by the server.');
}
alreadyPurchaseIdsArray
作为参数传递给存储过程。
希望它对你有所帮助。