登录
首页 >  Golang >  Go问答

Mongo Go 驱动程序 Count() 方法从 Azure CosmosDB MongoDB Api Count() 获取“服务器响应无效,值字段不是数字”

来源:stackoverflow

时间:2024-04-27 15:45:36 343浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《Mongo Go 驱动程序 Count() 方法从 Azure CosmosDB MongoDB Api Count() 获取“服务器响应无效,值字段不是数字”》,聊聊,希望可以帮助到正在努力赚钱的你。

问题内容

我在我的项目中使用 azure cosmos db 和 mongodb api,该项目是使用 golang 和 mongodb go 驱动程序开发的。当我尝试使用下面的代码获取计数时,出现错误 invalid response from server, value field is not a number

itemcount, err := mycollection.countdocuments(ctx, bson.d{{"$and", bson.a{bson.m{"userid": user.id, "siteid": site.id}}}})

当我在 mongodb 数据库上尝试时,相同的代码返回项目数(在本例中为 532)。 然后,我决定通过编写一个简单的 .net 应用程序来尝试相同的查询,该应用程序在 mongodb 和 cosmosdb 上都运行良好。下面是我使用的代码,它为两个数据库打印了 532

var count = database.GetCollection("myCollection").CountDocuments(filter);
Console.WriteLine(count);

我还尝试通过 robo3t 查询这两个数据库。查询 db.getcollection('consents').count({}) 从 mongodb 返回 532,而同一查询从 cosmosdb 返回 numberlong(532)

我将这一行为写到了 msdn 论坛,但没有人相信。我什至不确定这是数据库 api 还是驱动程序的问题。就驱动程序而言,它可以与 mongodb 配合使用,这也是它向我承诺的。就数据库 api 而言,它与 .net 驱动程序一起使用,它告诉我 microsoft 很清楚这种行为,并发现它可以接受并在其驱动程序中处理它。有人知道如何克服这种情况吗?


解决方案


你的过滤器应该是:

itemCount, err := myCollection.CountDocuments(ctx, bson.M{"userid": user.ID, "siteid": site.ID})

bson.m 将执行隐式 $and

本篇关于《Mongo Go 驱动程序 Count() 方法从 Azure CosmosDB MongoDB Api Count() 获取“服务器响应无效,值字段不是数字”》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>