标签: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. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。