在documentDb中查询时,有效地不是EXSISTS吗?

时间:2018-05-15 01:25:31

标签: performance nosql azure-cosmosdb

我们假设我们有两个集合,一个用户集合和一个项目集合。

用户集合,每个用户文档存储用户的购买产品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多件商品,这是否有效?

有效的方法是什么?

1 个答案:

答案 0 :(得分:0)

到目前为止,我的researchExistNOT 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作为参数传递给存储过程。

希望它对你有所帮助。