栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

CosmosDb计算不同元素

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

CosmosDb计算不同元素

[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限制,并且不会成功。如果是这种情况,您可以在服务器端实现类似的代码,但效果并不理想。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/369593.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号