我想用mongo-go-driver创建一个动态过滤器。
例如,我有这样的文档:
{
"_id":"5d1231380a2a2b39a99c3ed1"},
"name":"flower.png",
"colors":["#ffffff","#212121","#999999","#dbdbdb","#ff5252"],
},
{
"_id":"5d1231380a2a2b39a99c3ed0"},
"name":"image of go.jpg",
"colors":["#dedede","#dfdfdf","#dddddd","#e0e0e0","#e2e2e2"],
},
{
"_id":"5d1231380a2a2b39a99c3ecf"},
"name":"bolket rulez.png",
"colors":["#000000","#010101","#020202","#030303","#040404"],
},
{
"_id":"5d1231380a2a2b39a99c3ecf"},
"name":"bolket photo.png",
"colors":["#ffffff","#010101","#020202","#030303","#040404"],
}现在我想要名称中有"bolket“和颜色为"#ffffff”的所有文档。
我尝试过这个过滤器:
filter := make(bson.D, 2)
if f.Name != "" {
filter = append(filter, bson.E{Key: "name", Value: bson.M{"$text": bson.M{"$search": f.Name}}})
}
if f.Color != "" {
filter = append(filter, bson.E{Key: "colors", Value: bson.M{"$in": f.Color}})
}但是对于这个过滤器,我有这个错误:(BadValue) unknown operator: $text
如何创建动态过滤器?
发布于 2019-06-29 20:40:29
query op $text search 跨文档上的文本索引字段,您不能使用$text执行单个字段搜索
假设您已经在name上创建了一个文本索引,然后尝试:
if f.Name != "" {
filter = append(filter, bson.E{Key: "$text", Value: bson.M{"$search": f.Name}})
}https://stackoverflow.com/questions/56776608
复制相似问题