为什么 mongo-go-driver 聚合结果对象键返回为 "Key"
Why mongo-go-driver aggregation result object keys returned as "Key"
我想用 mongo-go-driver 使用聚合对一些数据进行分组,但是 json 结果让我很困惑,因为行键被 "Key" 替换了,而且真正的键成为 "Key" 的值
var result primitive.A
pipeline := mongo.Pipeline{{{"$group", bson.D{{"_id", "$nis"}}}}}
cursor, err := db.NilaiUH.Aggregate(context.TODO(), pipeline)
cursor.All(context.Background(), &result)
json.NewEncoder(w).Encode(&result)
这是结果
[
[
{
"Key": "_id",
"Value": 15100
}
],
[
{
"Key": "_id",
"Value": 15101
}
]
]
新版本的 MongoDB 驱动程序将空接口视为键值数组,而不是字符串和空接口之间的映射。我已使用以下代码更正了该问题:
// register custom codec registry to handle empty interfaces
rb := bson.NewRegistryBuilder()
rb.RegisterTypeMapEntry(bsontype.EmbeddedDocument, reflect.TypeOf(bson.M{}))
client, err := mongo.NewClient(options.Client().ApplyURI(url).SetRegistry(rb.Build()))
我想用 mongo-go-driver 使用聚合对一些数据进行分组,但是 json 结果让我很困惑,因为行键被 "Key" 替换了,而且真正的键成为 "Key" 的值
var result primitive.A
pipeline := mongo.Pipeline{{{"$group", bson.D{{"_id", "$nis"}}}}}
cursor, err := db.NilaiUH.Aggregate(context.TODO(), pipeline)
cursor.All(context.Background(), &result)
json.NewEncoder(w).Encode(&result)
这是结果
[
[
{
"Key": "_id",
"Value": 15100
}
],
[
{
"Key": "_id",
"Value": 15101
}
]
]
新版本的 MongoDB 驱动程序将空接口视为键值数组,而不是字符串和空接口之间的映射。我已使用以下代码更正了该问题:
// register custom codec registry to handle empty interfaces
rb := bson.NewRegistryBuilder()
rb.RegisterTypeMapEntry(bsontype.EmbeddedDocument, reflect.TypeOf(bson.M{}))
client, err := mongo.NewClient(options.Client().ApplyURI(url).SetRegistry(rb.Build()))