我在查询我的 mongoDB 时尝试使用排序功能,但它失败了。相同的查询在 MongoDB 控制台中有效,但在此处无效。代码如下:
import pymongo
from pymongo import Connection
connection = Connection()
db = connection.myDB
print db.posts.count()
for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({u'entities.user_mentions.screen_name':1}):
print post
我得到的错误如下:
Traceback (most recent call last):
File "find_ow.py", line 7, in <module>
for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({'entities.user_mentions.screen_name':1},1):
File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/cursor.py", line 430, in sort
File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/helpers.py", line 67, in _index_document
TypeError: first item in each key pair must be a string
我在其他地方找到了一个链接,上面说如果使用 pymongo,我需要在 key 前面放置一个“u”,但这也不起作用。其他任何人都能让它工作,或者这是一个错误。
最佳答案
.sort()
,在pymongo中,以key
和direction
为参数。
因此,如果您想按 id
进行排序,那么您应该 .sort("_id", 1)
对于多个字段:
.sort([("field1", pymongo.ASCENDING), ("field2", pymongo.DESCENDING)])
https://stackoverflow.com/questions/8109122/
相关文章:
mongodb - Node.js Mongoose.js 字符串到 ObjectId 函数
mongodb - 如何检查数组字段是否包含唯一值或 MongoDB 中的另一个数组?
mongodb - 如何在 mongodb 上导入 .bson 文件格式
node.js - 在 Mongoose 中,我如何按日期排序? (node.js)
node.js - 将 created_at 和 updated_at 字段添加到 Mongoose
mongodb - Mongodb中的保存和插入有什么区别?