我想从集合中返回值,一个是批处理,它应该与特定的过滤器不同,即value=“尼斯”,另一个是供应商。我不能得到供应商的价值吗?
如何使用Distinct实现这一点,是否必须使用Find()?
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
filter := bson.D{{Key: "batch", Value: ""}}
values, err := db.Collection("xyzcollection").Distinct(ctx, "batch", filter)
if err != nil {
return nil, err
}
batch := make([]string, len(values))
for i, v := range values {
batch[i] = v.(string)
}
fmt.Println(batch)发布于 2021-10-07 10:04:01
经过普拉萨德的评论,我已经用这个解决方案解决了我的问题。
type Example struct {}
var exm []Example
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
pipeline := []bson.M{
{"$match": bson.M{"status": "Pending"}},
{"$group": bson.M{"_id": "$batch"}},
}
cursor, err := db.Collection("xyzcollection").Aggregate(ctx, pipeline)
if err != nil {
return []Example{}, errors.New(fmt.Sprintf("unable to retrive data: %s ", err.Error()))
}
var result Example
for cursor.Next(ctx) {
cursor.Decode(&result)
exm = append(exm, result)
}
return exm, nil发布于 2021-10-06 17:07:39
https://stackoverflow.com/questions/69467610
复制相似问题