登录
首页 >  Golang >  Go问答

Golang mongoDB 搜索文档

来源:stackoverflow

时间:2024-04-09 20:51:34 364浏览 收藏

今天golang学习网给大家带来了《Golang mongoDB 搜索文档》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~

问题内容

我开始学习 mongodb,并尝试通过一些参数(用户名、名字、姓氏)搜索用户。在下面的示例中,我可以按用户名搜索用户并获取数据。

// search users
func (r *mongo) search(ctx context.context, query string) ([]*user, error) {
    findoptions := options.find()
    // sort by `username` field descending
    findoptions.setsort(bson.d{{"username", -1}})

    filter := bson.m{"username": bson.m{"$regex": query, "$options": "i"}}
    cursor, err := r.col.find(ctx, filter, findoptions)
    if err != nil {
        return nil, err
    }

    var results []*user
    if err = cursor.all(ctx, &results); err != nil {
        return nil, err
    }

    return results, nil
}

以下示例搜索多个参数,但结果为空。

// Search users
func (r *Mongo) Search(ctx context.Context, query string) ([]*User, error) {
    findOptions := options.Find()
    // Sort by `username` field descending
    findOptions.SetSort(bson.D{{"username", -1}})

    filter := bson.M{
        "username": bson.M{"$regex": query, "$options": "i"},
        "$or": []interface{}{
            bson.M{"firstname": bson.M{"$regex": query, "$options": "i"}},
            bson.M{"lastname": bson.M{"$regex": query, "$options": "i"}},
        },
    }

    // filter := bson.M{"username": bson.M{"$regex": query, "$options": "i"}}
    cursor, err := r.col.Find(ctx, filter, findOptions)
    if err != nil {
        return nil, err
    }

    var results []*User
    if err = cursor.All(ctx, &results); err != nil {
        return nil, err
    }

    return results, nil
}

问题,如何通过多个参数进行搜索(使用$or)?

这个搜索选项是否最优且正确,或者 mongodb 中是否有更正确的搜索选项(类似于 sql 中的 like)?

提前感谢您的回答。


正确答案


如果有人需要通过多个参数进行搜索,这可能很有用: 我将过滤器组件放在单独的方法中

func (r *Mongo) queryBuilderFilter(query *Query) bson.M {
    var andFilters []bson.M

    if query.Query != "" {
        orFilters := []bson.M{
            {
                "username": bson.M{"$regex": primitive.Regex{Pattern: "^" + query.Query + "*", Options: "i"}},
            },
            {
                "firstname": bson.M{"$regex": primitive.Regex{Pattern: "^" + query.Query + "*", Options: "i"}},
            },
            {
                "lastname": bson.M{"$regex": primitive.Regex{Pattern: "^" + query.Query + "*", Options: "i"}},
            },
        }
        andFilters = append(andFilters, bson.M{"$or": orFilters})
    }

    if len(andFilters) == 0 {
        // Handle empty and, since there must be one item.
        return bson.M{}
    }
    return bson.M{"$and": andFilters}
}

本篇关于《Golang mongoDB 搜索文档》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>