mongo mgo v2中 聚合查询 中怎么使用动态条件?

where := bson.M{"$match": bson.M{"user_id": userId, "bank_id": bankId, "knowledge_points": bson.M{"$in": Knowledge}, "difficulty": difficulty}}

num := bson.M{"$sample": bson.M{"size": questionNum}}

err := repo.collection().Pipe([]bson.M{where, num}).All(&b)
if err != nil {
    return nil, err
}

请教 以上代码 where 条件中 "knowledge_points": bson.M{"$in": Knowledge}, "difficulty": difficulty是可选项,如果有值才会进行匹配,请问该怎么写?

阅读 3.4k
1 个回答

经查 bson.M 是

type M map[string]interface{}

类型
所以这样就可以了

var query map[string]interface{}
    query = make(map[string]interface{})
    query["user_id"] = userId
    if bankId > 0 {
        query["bank_id"] = bankId
    }
    if difficulty != "" {
        query["difficulty"] = difficulty
    }
    
    where := bson.M{"$match": query}

    num := bson.M{"$sample": bson.M{"size": questionNum}}

    err := repo.collection().Pipe([]bson.M{where, num}).All(&b)
    if err != nil {
        return nil, err
    }
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题