为了账号安全,请及时绑定邮箱和手机立即绑定

pymongo - 搜索包含 $and 不区分大小写的文档的集合

pymongo - 搜索包含 $and 不区分大小写的文档的集合

米脂 2021-08-14 19:33:36
我正在尝试搜索包含文档的集合,集合如下所示:[{'description':'Fast and Dangerous','colour':'blue','make':'ford'},{'description':'slow and dangerous','colour':'red','make':'lexus'}]我正在尝试构建一个搜索查询,该查询将返回包含 Red 和 Dangerous(不区分大小写)的所有文档我开始于:find({"$text": {"$search": "red dangerous"}})但是,这当然不区分大小写,但它是 OR 而不是 AND。我已经通读了https://docs.mongodb.com/manual/reference/operator/query/and/#op._S_and - 但这意味着您必须参考可能包含红色或危险的特定字段,而不是整个文档。解决这个问题的最佳方法是什么?我希望我的代码是专业的,我觉得我想出的任何 hack 都不会。任何指针?
查看完整描述

1 回答

?
眼眸繁星

TA贡献1873条经验 获得超9个赞

您可以$meta在$sort舞台上使用聚合。就像是


db.collection.aggregate([

  { "$match": { "$text": { "$search": "red Dangerous" } } },

  { "$addFields": { "score": { "$meta": "textScore" } } },

  { "$sort": { "score": 1 } }

])

文本分数表示文档与一个或多个搜索词的匹配程度。因此,最匹配的文档将始终排在最前面。


查看完整回答
反对 回复 2021-08-14
  • 1 回答
  • 0 关注
  • 218 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号