python – MongoDb:$按$in排序

我正在使用$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适合您.

上一篇:Java通过反射得到其属性的值包含父类属性


下一篇:【Python pymongo】_