ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

python – MongoDb:$按$in排序

2019-07-29 07:58:20  阅读:276  来源: 互联网

标签:python sorting mongodb pymongo


我正在使用$in运算符运行mongodb find查询:

collection.find({name: {$in: [name1, name2, ...]}})

我希望结果的排序方式与我的名字数组相同:[name1,name2,…].我该如何实现这一目标?

注意:我通过pymongo访问MongoDb,但我认为没有任何重要性.

编辑:由于在MongoDb中无法实现这一目标,我最终使用了典型的Python解决方案:

names = [name1, name2, ...]
results = list(collection.find({"name": {"$in": names}}))
results.sort(key=lambda x: names.index(x["name"]))

解决方法:

不可能. $in运算符检查存在.该列表被视为集合.

选项:

>拆分name1 … nameN的几个查询或以相同的方式过滤结果.
更多名称 – 更多查询.
>使用itertools groupby / ifilter.在这种情况下 – 将“排序优先”标志添加到每个文档,并将name1与PREC1匹配,将name2与PREC2,….匹配,然后由PREC分组,然后由PREC分组.

如果您的集合在“名称”字段上有索引 – 选项1更好.
如果没有索引,或者由于高写/读率而无法创建索引 – 选项2适合您.

标签:python,sorting,mongodb,pymongo
来源: https://codeday.me/bug/20190729/1569199.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有