DAY 228 python & mongo问题记录
python & mongo问题记录
背景介绍
使用python
操作mongo
进行的一些操作记录,为了方便日后可以快速的解决类似问题。
准备工作
为了尽可能简单的说明,我将插入几条简单的数据。
from pymongo import MongoClient
client = MongoClient('mongodb://your-mongo-username:your-mongo-password@localhost:27017/your-db')
db = client.your-db
collection = db.your_collection
获得集合句柄后,则可以先进行插入数据操作。
collection.insert_one({"name":"frank","age":24})
collection.insert_one({"name":"landpack","age":4})
collection.insert_one({"name":"jack","age":14})
然后可以执行一条查询操作,来看看结果。
>>> collection.find()
<pymongo.cursor.Cursor object at 0x7f0c13017750>
如果你也是使用python
的交互环境进行运行如上代码的你也会看到我们得到了一个游标。
接下来把游标里面的数据拿出来。
>>> cursor = collection.find()
>>> for c in cursor:
... print c
...
{u'age': 24, u'_id': ObjectId('58455610e138231725c0f6eb'), u'name': u'frank'}
{u'age': 4, u'_id': ObjectId('58455622e138231725c0f6ec'), u'name': u'landpack'}
{u'age': 14, u'_id': ObjectId('58455631e138231725c0f6ed'), u'name': u'jack'}
>>>
####查询最新的一条记录
下面我们来研究第一个主题,查询最新的一条记录。也就是最后插入的一条记录。
现在有那么多条记录,假设我们只关心其中最后插入的那条,我们可以用下面的方式。
>>> cursor = collection.find().limit(1).sort('_id', -1)
>>> for c in cursor:
... print c
...
{u'age': 14, u'_id': ObjectId('58455631e138231725c0f6ed'), u'name': u'jack'}
可以看到,我们得到了想要的结果,再试试如下方式。
>>> for c in cursor:
... print c
...
{u'age': 14, u'_id': ObjectId('58455631e138231725c0f6ed'), u'name': u'jack'}
同样拿到了想要的结果,我们还可以用下面的方式。
>>> cursor = collection.find().limit(1).sort('$natural',-1)
>>> for c in cursor:
... print c
...
{u'age': 14, u'_id': ObjectId('58455631e138231725c0f6ed'), u'name': u'jack'}
这几种方式都拿到了结果,哪种方式更高效呢?暂时未知。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
2021-02-24 DAY 32 PYTHON入门