jjzjj

mongodb - mgo:查找类型为 number (int, float64) 的字段不起作用

coder 2023-07-02 原文

我正在为 MongoDB 开发一个 RESTful API 和 mgo 驱动程序。

问题是我试图通过 int 类型的字段获取文档,但没有返回任何结果。

例如我有这个文档:

{
  "_id" : ObjectId("5797833e9de6f8c5615a20f9"),
  "id" : "28743915-9be0-427d-980d-5009bfe1b13a",
  "name" : "Hunter",
  "rating" : 2.9,
  "downloads" : 5040
}

当尝试获取此文档时:

conn.Session.
    DB("face").
    C("papers").
    Find(bson.M{"rating": 2.9}).
    All(&papers) // papers is an instance of a slice struct.

它不会返回任何文档,但在 mongo shell 中执行相同操作会返回文档,例如:

db.papers.find({"rating": 2.9})

但是在 mongo shell 中这样做不会返回任何文档:

db.papers.find({"rating": "2.9"})

所以我认为问题可能在于,当 bson.M 被序列化时,它可能会将值转换为字符串,因为 bson.M 是一个map[string]接口(interface){}

这就是 Paper 结构的样子

type Paper struct {
    ID          string         `json:"id,omitempty" bson:"id"`
    Name        string         `json:"name,omitempty" bson:"name"`
    Rating      float64        `json:"rating" bson:"rating"`
    Downloads   int            `json:"downloads" bson:"downloads"`
}

最佳答案

我正在尝试了解您的问题是什么,但不能。最令人困惑的部分是你的问题解释

  1. I'm trying to fetch documents by a field of type int

  2. Find(bson.M{"rating": 2.9}).

  3. "rating" : 2.9

在哪个世界 2.9 是整数?

  1. Go 和 Mongo 都没有类型 number(您在标题中提到过)。
  2. 如果您使用mgo 插入float64,它会作为double 插入到Mongo 中。
  3. 您不能使用string 查询来查询double。所以 db.papers.find({"rating": 2.9}) 返回文档,而 db.papers.find({"rating": "2.9"}) - 不,即使有一些文档带有 "rating": 2.9

mgomongo 都没有错误。如果您有兴趣,下面是使用您的 Paper 类插入 map 和检索数据的示例代码:

package main

import (
    "gopkg.in/mgo.v2"
    "gopkg.in/mgo.v2/bson"
    "fmt"
)

type Paper struct {
    ID          string         `json:"id,omitempty" bson:"id"`
    Name        string         `json:"name,omitempty" bson:"name"`
    Rating      float64        `json:"rating" bson:"rating"`
    Downloads   int            `json:"downloads" bson:"downloads"`
}

func main() {
    session, err := mgo.Dial("mongodb://127.0.0.1:27017/face")

    if err != nil {
        panic(err)
    }
    defer session.Close()
    session.SetMode(mgo.Monotonic, true)

    c := session.DB("face").C("papers")
    c.Insert(bson.M{
        "id": "28743915-9be0-427d-980d-5009bfe1b13a",
        "name": "Hunter",
        "rating": 2.9,
        "downloads": 5040,
    })

    var papers []Paper
    c.Find(bson.M{"rating": 2.9}).All(&papers) // equivalent of db.papers.find({"rating": 2.9})
    fmt.Printf("%+v\n", papers)
}

关于mongodb - mgo:查找类型为 number (int, float64) 的字段不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38632832/

有关mongodb - mgo:查找类型为 number (int, float64) 的字段不起作用的更多相关文章

  1. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  2. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  3. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  4. ruby - 当使用::指定模块时,为什么 Ruby 不在更高范围内查找类? - 2

    我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or

  5. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  6. C# 到 Ruby sha1 base64 编码 - 2

    我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha

  7. ruby-on-rails - 在 Rails 中更高效地查找或创建多条记录 - 2

    我有一个应用需要发送用户事件邀请。当用户邀请friend(用户)参加事件时,如果尚不存在将用户连接到该事件的新记录,则会创建该记录。我的模型由用户、事件和events_user组成。classEventdefinvite(user_id,*args)user_id.eachdo|u|e=EventsUser.find_or_create_by_event_id_and_user_id(self.id,u)e.save!endendend用法Event.first.invite([1,2,3])我不认为以上是完成我的任务的最有效方法。我设想了一种方法,例如Model.find_or_cr

  8. ruby - 查找重叠的正则表达式匹配项 - 2

    我想找到给定字符串中的所有匹配项,包括重叠匹配项。我怎样才能实现它?#Example"a-b-c-d".???(/\w-\w/)#=>["a-b","b-c","c-d"]expected#Solutionwithoutoverlappedresults"a-b-c-d".scan(/\w-\w/)#=>["a-b","c-d"],but"b-c"ismissing 最佳答案 在积极的前瞻中使用捕获:"a-b-c-d".scan(/(?=(\w-\w))/).flatten#=>["a-b","b-c","c-d"]参见Rubyde

  9. ruby - 在 Ruby 中查找多个正则表达式匹配的模式和位置 - 2

    这应该是一个简单的问题,但我找不到任何相关信息。给定一个Ruby中的正则表达式,对于每个匹配项,我需要检索匹配的模式$1、$2,但我还需要匹配位置。我知道=~运算符为我提供了第一个匹配项的位置,而string.scan(/regex/)为我提供了所有匹配模式。如果可能,我需要在同一步骤中获得两个结果。 最佳答案 MatchDatastring.scan(regex)do$1#Patternatfirstposition$2#Patternatsecondposition$~.offset(1)#Startingandendingpo

  10. ruby-on-rails - Rails 基本 Base64 身份验证 - 2

    我正在尝试复制此GETcurl请求:curl-D--XGET-H"Authorization:BasicdGVzdEB0YXByZXNlYXJjaC5jb206NGMzMTg2Mjg4YWUyM2ZkOTY2MWNiNWRmY2NlMTkzMGU="-H"Content-Type:application/json"http://staging.example.com/api/v1/campaigns在Ruby中,通过电子邮件+apikey生成身份验证:auth="Basic"+Base64::encode64("test@example.com:4c3186288ae23fd9661c

随机推荐