mongodb - 如何使用官方的 mongo-go-driver 从 mongo 文档中过滤字段

标签 mongodb go struct projection mongo-go

如何使用 mongo-go-driver 过滤字段。 尝试使用 findopt.Projection 但没有成功。

type fields struct {
    _id int16
}

s := bson.NewDocument()
filter := bson.NewDocument(bson.EC.ObjectID("_id", starterId))

var opts []findopt.One
opts = append(opts, findopt.Projection(fields{
    _id: 0,
}))

staCon.collection.FindOne(nil, filter, opts...).Decode(s)

最后,我想压制字段“_id”。但是文件没有改变。

最佳答案

编辑:随着 mongo-go 驱动程序的发展,可以使用简单的 bson.M 指定投影。像这样:

options.FindOne().SetProjection(bson.M{"_id": 0})

原始(旧)答案如下。


它对您不起作用的原因是因为字段 fields._id 未导出,因此,没有其他包可以访问它(只有声明包)。

您必须使用导出的字段名称(后者以大写字母开头),例如ID,并使用 struct tags将其映射到 MongoDB _id 字段,如下所示:

type fields struct {
    ID int `bson:"_id"`
}

现在使用投影执行查询:

projection := fields{
    ID: 0,
}
result := staCon.collection.FindOne(
    nil, filter, options.FindOne().SetProjection(projection)).Decode(s)

请注意,您也可以使用 bson.Document作为投影,您不需要自己的结构类型。例如。以下做同样的事情:

projection := bson.NewDocument(
    bson.EC.Int32("_id", 0),
)
result := staCon.collection.FindOne(
    nil, filter, options.FindOne().SetProjection(projection)).Decode(s)

关于mongodb - 如何使用官方的 mongo-go-driver 从 mongo 文档中过滤字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53120116/

相关文章:

javascript - 如何执行使用 AND 和 OR 的条件 Mongoose 查询?

mongodb - MongoEngine - 在转换为 json 时如何有效地引用列表字段

goroutine 等待 channel 的响应并继续

Goroutine 不运行

c - 名字不会显示

Node.js — mongoose 静态方法示例

javascript - onsubmit 中断 Jade View

go - 如何查询和处理使用 go.uuid 创建并插入到 PostgreSQL 11 中的 UUID?

c - 指向嵌套结构中的结构的指针

c - 如何扫描除第一行以外的行中的值