Python操作Mongo数据库
连接数据库
import pymongo
# 连接到数据库,以下两种方式均可
client = pymongo.MongoClient(host='localhost', port=27017)
client = pymongo.MongoClient('mongodb://localhost:27017')
# 指定连接的数据库,以下两种方式均可
db = client.demo
db = client['demo']
# 指定数据库的某个集合,以下两种方式均可
collection = db.demo_1
collection = db['demo_1']
插入数据
- insert_one(), 一次插入一条记录
- insert_many(), 一次插入多条记录
mongo默认会给每一条记录添加一个_id字段,用来唯一标识每一条记录。
# 一次插入一条记录
book = {
'name': '五年高考三年模拟',
'price': 50,
}
result = collection.insert_one(book)
print(result.inserted_id)
# 一次插入多条数据
book = [
{
'name': '五年高考',
'price': 50,
},
{
'name': '三年模拟',
'price': 30,
},
]
resutl = collection.insert_many(book)
可以使用result.inserted_id和result.inserted_ids来查看插入记录的_id编号。
查询数据
- find_one(), 查询一条记录, 以字典的形式直接返回数据结果。
- find(), 查询多条记录, 返回的是Cursor对象,需要遍历才能获取数据
# 查询单条记录
results = collection.find_one({'name': '五年高考'})
print(result)
# 查询多条记录
results = collection.find({'price': 50})
for result in results:
print(result)
mongo提供了一些高级的查询参数来实现更加灵活的数据查询。
比较运算符
| 符号 | 含义 | 例子 |
|---|---|---|
| $lt | 小于 | {'price': {'$lt':50}} |
| $gt | 大于 | {'price': {'$gt':30}} |
| $lte | 小于等于 | {'price': {'$lte':40}} |
| $gte | 大于等于 | {'price': {'$lte':30}} |
| $ne | 不等于 | {'price': {'$ne':30}} |
| $in | 在范围内 | {'price': {'$in':[30,50]}} |
| $nin | 不在范围内 | {'price': {'$nin':[30,40]}} |
正则表达式
| 符号 | 含义 | 例子 |
|---|---|---|
| $regex | 匹配正则 | {'name': {'$regex': '^M.*'}} |
| $exists | 属性是否存在 | {'name': {'$exists': True}} |
| $type | 类型判断 | {'age': {'$type': 'int'}} |
| $mod | 数字模操作 | {'age': {'$mod': [5, 0]}} |
| $text | 文本查询 | {'$text': {'$search': 'Mike'}} |
| $where | 高级条件查询 | {'$where': 'obj.fans_count == obj.follows_count'} |
更新数据
- update_one(), 只更新匹配到的第一条记录
- update_many(), 更新匹配到的全部记录
condition = {'name':'五年高考'}
price_change = {'price': 100}
# 方式1
result = collection.update_one(condition,price_change)
print(result)
# 方式2
result = collection.update_one(condition, {'$set': price_change})
print(result)
以上两种方式都是更新name为五年高考的字段,但是其结果却是不同的
方式一:
相当于查询到name为五年高考的字段,将其删除,再将待更新的数据添加上去。结果就是只剩下一个price为100的数据。
方式二:
查询到name为五年高考的字段,仅仅是将price更新为了100,其余不动。
另外可以调用result.matched_count, result.modified_count来查看匹配的条数和影响的条数。
删除数据
- delete_one(), 删除符合条件的第一条数据
- delete_many(), 删除符合条件的全部数据
# 删除一条
result = collection.delete_one({'name': '五年高考'})
print(result)
# 删除多条
result = collection.delete_many({'price':50}) # 删除价格为50的全部记录
result = collection.delete_many({'price':{'$gt':30}}) # 删除价格大于30的全部记录
另外可以调用result.deleted_count查看删除的条数。
其他常用方法
- count()
count = collection.find().count() # 查询表中全部记录的条数
count = collection.find({'price': {'$gt':30}}).count() # 价格大于30的条数
- sort()
results = collection.find().sort('name', pymongo.ASCENDING) # 按照name升序返回结果
results = collection.find().sort('price', pymongo.DECENDING) # 按照price降序返回结果
- limit()
results = collection.find().sort('name', pymongo.ASCENDING).limit(2) # 限制返回两条结果
Python操作Mongo数据库的更多相关文章
- python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查
python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...
- python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用
python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- Python操作Access数据库
我们在这篇文章中公分了五个步骤详细分析了Python操作Access数据库的相关方法,希望可以给又需要的朋友们带来一些帮助. AD: Python编 程语言的出现,带给开发人员非常大的好处.我们可以利 ...
- Windows下安装MySQLdb, Python操作MySQL数据库的增删改查
这里的前提是windows上已经安装了MySQL数据库,且配置完成,能正常建表能操作. 在此基础上仅仅需安装MySQL-python-1.2.4b4.win32-py2.7.exe就ok了.仅仅有1M ...
- 使用python操作mysql数据库
这是我之前使用mysql时用到的一些库及开发的工具,这里记录下,也方便我查阅. python版本: 2.7.13 mysql版本: 5.5.36 几个python库 1.mysql-connector ...
- python操作三大主流数据库(10)python操作mongodb数据库④mongodb新闻项目实战
python操作mongodb数据库④mongodb新闻项目实战 参考文档:http://flask-mongoengine.readthedocs.io/en/latest/ 目录: [root@n ...
- python操作三大主流数据库(9)python操作mongodb数据库③mongodb odm模型mongoengine的使用
python操作mongodb数据库③mongodb odm模型mongoengine的使用 文档:http://mongoengine-odm.readthedocs.io/guide/ 安装pip ...
- python操作三大主流数据库(1)python操作mysql①windows环境中安装python操作mysql数据库的MySQLdb模块mysql-client
windows安装python操作mysql数据库的MySQLdb模块mysql-client 正常情况下应该是cmd下直接运行 pip install mysql-client 命令即可,试了很多台 ...
随机推荐
- 也谈matlab中读取视频的一个重要函数mmreader
也谈matlab中读取视频的一个重要函数mmreader 在matlab中输入help mmreader来查阅一下该函数,有如下信息: MMREADER Create a multimedia rea ...
- Javascript判断Chrome浏览器
今天分享一下如何通过Javascript来判断Chrome浏览器,这里是通过userAgent判断的,检测一下userAgent返回的字符串里面是否包含“Chrome”, 具体怎么检测是通过index ...
- JS操作CSS随机改变网页背景
今天有个朋友在weibo上问我可不可以用JS和CSS让页面每次刷新随机产生一张背景图,当然我的回答是可以的.具体可以这样做: 1.用JS定义一个图片数组,里面存放你想要随机展示的图片 1 2 3 4 ...
- angular package.json中start build
"start": "ng serve --host 0.0.0.0 --port 4200 --proxy-config proxy.conf.json", & ...
- 【BZOJ】1778: [Usaco2010 Hol]Dotp 驱逐猪猡
[题意]给定无向图,炸弹开始在1,在每个点爆炸概率Q=p/q,不爆炸则等概率往邻点走,求在每个点爆炸的概率.n<=300. [算法]概率+高斯消元 [题解]很直接的会考虑假设每个点爆炸的概率,无 ...
- 在Unity中实现屏幕空间阴影(2)
参考文章: https://www.imgtec.com/blog/implementing-fast-ray-traced-soft-shadows-in-a-game-engine/ 完成的工程: ...
- React Native 与 夜神模拟器的绑定
之前一直用真机去调试, 每回更新一次都需要手动摇晃手机后才能reload JS, OMG,太麻烦了. 后来寻思模拟器网上推荐用Geny...什么的模拟器,但是那个模拟器还需要VBox一起用. 有点麻烦 ...
- VueJS 获取并编译远程模板 解决方案(简单版)
原文链接:https://savokiss.com/tech/vuejs-remote-template.html see: forum
- es6新语法Object.assign()
1.介绍 Object.assign用于对象的合并,将源对象的所有可枚举属性复制到目标对象,只拷贝源对象自身的属性继承属性补考呗 Object.assign(target,source1,...)第一 ...
- 一个JAVA渣渣的校招成长记,附BAT美团网易等20家面经总结
欢迎关注我的微信公众号:"Java面试通关手册"(坚持原创,分享美文,分享各种Java学习资源,面试题,以及企业级Java实战项目回复关键字免费领取): 今天分享一篇牛客网上的一个 ...