8

如何使用 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”。但文件没有改变。

4

1 回答 1

14

编辑:随着 mongo-go 驱动程序的发展,可以使用如下简单的方式指定投影bson.M

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

原始(旧)答案如下。


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

您必须使用导出的字段名称(以大写字母开头),例如ID,并使用结构标签将其映射到 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)

请注意,您也可以使用 abson.Document作为投影,您不需要自己的结构类型。例如,以下内容也一样:

projection := bson.NewDocument(
    bson.EC.Int32("_id", 0),
)
result := staCon.collection.FindOne(
    nil, filter, options.FindOne().SetProjection(projection)).Decode(s)
于 2018-11-05T13:54:45.653 回答