加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – MongoDb:$按$in排序

发布时间:2020-12-20 11:25:22 所属栏目:Python 来源:网络整理
导读:我正在使用$in运算符运行 mongodb find查询: collection.find({name: {$in: [name1,name2,...]}}) 我希望结果的排序方式与我的名字数组相同:[name1,…].我该如何实现这一目标? 注意:我通过pymongo访问MongoDb,但我认为没有任何重要性. 编辑:由于在Mongo
我正在使用$in运算符运行 mongodb find查询:

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

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

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

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

names = [name1,...]
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适合您.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读