使用 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
uint8
是 byte
的别名,而 []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
驱动程序的一部分开发(现在不受支持且已过时)。不要混合使用不同的驱动程序。
您应该删除从 i
到 uint8
的转换,这样才能获得正确的数据代码。
// 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()
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
uint8
是 byte
的别名,而 []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
驱动程序的一部分开发(现在不受支持且已过时)。不要混合使用不同的驱动程序。
您应该删除从 i
到 uint8
的转换,这样才能获得正确的数据代码。
// 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()