我正在使用 MGO 与 mongodb 进行通信。 我想在集合中搜索,并按搜索分数对结果进行排序。
collection.Find(bson.M{
"$text": bson.M{"$search": "mysearch"},
"score": bson.M{"$meta": "textScore"},
})
但我收到此错误:
Can't canonicalize query: BadValue unknown operator: $meta (status code : 500)
当我只尝试使用 $text 时,它有效。
我使用与这里相同的 bson 结构: MongoDB - Can't canonicalize query: BadValue unknown operator: $meta
谢谢
最佳答案
这里的问题是您使用 BSON“ map ”作为参数,并将“投影”作为“查询”的一部分。而是使用 .Select()
投影链接方法:
collection.Find(
bson.M{ "$text": bson.M{ "$search": "mysearch" } }
).Select(
bson.M{ "score": bson.M{ "$meta": "textScore" } }
)
就像标准 API 示例一样,“查询”和“投影”部分彼此“分离”。
关于mongodb - MGO : Can't canonicalize query: BadValue unknown operator: $meta,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31607964/