[2020年11月19日更新]
这是另一个解决地区问题并适用于的查询
count。基本上,您需要封装不重复内容然后进行计数。我们已经通过分页对它进行了测试,以查找您想要唯一记录的情况,而不仅是计数,而且它正在起作用。
select value count(1) from c join (select distinct value c from p in c.products)
您还可以
where根据条件所基于的内容,在括号的内部和外部使用子句。
这在另一个答案中也略有不同。
查看CosmosDB的select子句文档。
@ssmsexe引起了我的注意,我想在这里更新答案。
[原始回答]
2018年10月19日添加了对 distinct的
支持
下面的查询工作正常
SELECT distinct value c FROM c join p in c.products
但是,它仍然无法计数。
计算不重复计数的 解决方法 是创建一个存储过程来执行不重复计数。它将基本上查询并继续到最后并返回计数。
如果将类似的查询传递给下面的存储过程,则将得到一个不同的计数
function count(queryCommand) { var response = getContext().getResponse(); var collection = getContext().getCollection(); var count = 0; query(queryCommand); function query(queryCommand, continuation){ var requestOptions = { continuation: continuation }; var isAccepted = collection.querydocuments( collection.getSelflink(), queryCommand, requestOptions, function (err, feed, responseOptions) { if (err) { throw err; } // Scan results if (feed) { count+=feed.length; } if (responseOptions.continuation) { // Continue the query query(queryCommand, responseOptions.continuation) } else { // Return the count in the response response.setBody(count); } }); if (!isAccepted) throw new Error('The query was not accepted by the server.'); }}该解决方法的问题在于,它可能会超过您收藏中的RU限制,并且不会成功。如果是这种情况,您可以在服务器端实现类似的代码,但效果并不理想。



