使用 mongodb $in 查询时,如果使用 [] uint8 进行查询,则会出现“(BadValue) $in 需要一个数组”错误。为什么?

When using the mongodb $in query, the "(BadValue) $in needs an array" error occurs if [] uint8 is used for the query. Why?

everyone.When 我在 mongodb $in 查询选择器中使用 []uint8 数组,出现“(BadValue) $in 需要一个数组”错误。 有人可以帮我吗?谢谢!!!

我的复制步骤如下:

Mongodb 信息

mongodb驱动版本为v1.8.1

$ mongo --host 192.168.64.6
MongoDB shell version v4.0.3
connecting to: mongodb://192.168.64.6:27017/
Implicit session: session { "id" : UUID("e4d7cea2-ab81-45ad-a51e-e7acf45a7242") }
MongoDB server version: 4.4.8
WARNING: shell and server versions do not match

mongos> use testing
switched to db testing
mongos> db.numbers.find()
{ "_id" : ObjectId("61b71d3d73b251bceee62032"), "type" : 0, "value" : 0 }
{ "_id" : ObjectId("61b71d3d73b251bceee62033"), "type" : 1, "value" : 1 }
{ "_id" : ObjectId("61b71d3d73b251bceee62034"), "type" : 2, "value" : 2 }
{ "_id" : ObjectId("61b71d3d73b251bceee62035"), "type" : 3, "value" : 3 }
{ "_id" : ObjectId("61b71d3d73b251bceee62036"), "value" : 4, "type" : 4 }
{ "_id" : ObjectId("61b71d3d73b251bceee62037"), "value" : 5, "type" : 5 }
{ "_id" : ObjectId("61b71d3d73b251bceee62038"), "type" : 6, "value" : 6 }
{ "_id" : ObjectId("61b71d3d73b251bceee62039"), "type" : 7, "value" : 7 }
{ "_id" : ObjectId("61b71d3d73b251bceee6203a"), "type" : 8, "value" : 8 }
{ "_id" : ObjectId("61b71d3d73b251bceee6203b"), "type" : 9, "value" : 9 }


转到代码

package main

import (
    "context"
    "fmt"
    "time"

    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
    "go.mongodb.org/mongo-driver/bson"
)

func main() {
    // init mongodb client
    ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
    defer cancel()
    client, err := mongo.Connect(ctx, options.Client().ApplyURI("mongodb://192.168.64.6:27017/"))
    if err != nil {
        fmt.Println(err)
        return
    }

    // mock some data
    collection := client.Database("testing").Collection("numbers")
    for i := 0; i < 10; i++ {
        _, err = collection.InsertOne(ctx, bson.M{"type": uint8(i), "value": i})
        if err != nil {
            fmt.Println(err)
            return
        }
    }

    // query
    filter := bson.M{"type": bson.M{"$in": []uint8{1, 2, 3}}}
    res := collection.FindOne(ctx, filter)
    if err = res.Err(); err != nil {
        fmt.Println(err)
        return
    }
}

结果

当我在命令行启动命令时,我得到如下输出:

go run main.go

(BadValue) $in needs an array

uint8byte 的别名,而 []byte 是一种特殊类型,它的处理方式与其他切片类型不同(不是数字切片)。 []byte 值使用 bsoncodec.ByteSliceCodec and other slice values are encoded using bsoncodec.SliceCodec.

编码

使用任何其他数字类型的切片,例如[]int8[]int:

filter := bson.M{"type": bson.M{"$in": []int{1, 2, 3}}}

注意:mongo 驱动程序有自己的 BSON 实现和包,请使用:go.mongodb.org/mongo-driver/bson。在您的示例中,您正在导入和使用 gopkg.in/mgo.v2/bson 这是一个完全不同的 BSON 实现,作为 mgo 驱动程序的一部分开发(现在不受支持且已过时)。不要混合使用不同的驱动程序。

您应该删除从 iuint8 的转换,这样才能获得正确的数据代码。

// mock some data
collection := client.Database("testing").Collection("numbers")
for i := 0; i < 10; i++ {
    _, err = collection.InsertOne(ctx, bson.M{"type": i, "value": i})
    if err != nil {
        fmt.Println(err)
        return
    }
}

 res := collection.FindOne(ctx, bson.M{
    "type": bson.M{
        "$in": []int{1, 2, 3},
    },
})
if res.Err()!=nil{
        // handle error
}

然后您可以获取原始数据或解码为另一种类型,例如:

 res.DecodeBytes()