连接数据库

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_idresult.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数据库的更多相关文章

  1. python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

    python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

  2. python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用

    python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...

  3. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

  4. Python操作Access数据库

    我们在这篇文章中公分了五个步骤详细分析了Python操作Access数据库的相关方法,希望可以给又需要的朋友们带来一些帮助. AD: Python编 程语言的出现,带给开发人员非常大的好处.我们可以利 ...

  5. Windows下安装MySQLdb, Python操作MySQL数据库的增删改查

    这里的前提是windows上已经安装了MySQL数据库,且配置完成,能正常建表能操作. 在此基础上仅仅需安装MySQL-python-1.2.4b4.win32-py2.7.exe就ok了.仅仅有1M ...

  6. 使用python操作mysql数据库

    这是我之前使用mysql时用到的一些库及开发的工具,这里记录下,也方便我查阅. python版本: 2.7.13 mysql版本: 5.5.36 几个python库 1.mysql-connector ...

  7. python操作三大主流数据库(10)python操作mongodb数据库④mongodb新闻项目实战

    python操作mongodb数据库④mongodb新闻项目实战 参考文档:http://flask-mongoengine.readthedocs.io/en/latest/ 目录: [root@n ...

  8. python操作三大主流数据库(9)python操作mongodb数据库③mongodb odm模型mongoengine的使用

    python操作mongodb数据库③mongodb odm模型mongoengine的使用 文档:http://mongoengine-odm.readthedocs.io/guide/ 安装pip ...

  9. python操作三大主流数据库(1)python操作mysql①windows环境中安装python操作mysql数据库的MySQLdb模块mysql-client

    windows安装python操作mysql数据库的MySQLdb模块mysql-client 正常情况下应该是cmd下直接运行 pip install mysql-client 命令即可,试了很多台 ...

随机推荐

  1. errno错误号含义

    errno0 : Success errno1 : Operation not permitted errno2 : No such file or directory errno3 : No suc ...

  2. 你知道吗?.NET Framework 4.5 五个很棒的特性

    简介 自.NET 4.5发布已经过了差不多1年了.但是随着最近微软大多数的发布,与.NET开发者交流的问题显示,开发者仅知道一到两个特性,其他的特性仅仅停留在MSDN并以简单的文档形式存在着. 比如说 ...

  3. [php]unset函数

    unset($var); 释放一个变量空间 unset($var1, $var2...);释放多个变量空间 unset(var['数组元素内容']);释放数组元素 注意: 1.在函数内部释放全局变量和 ...

  4. 【Project Euler】530 GCD of Divisors 莫比乌斯反演

    [题目]GCD of Divisors [题意]给定f(n)=Σd|n gcd(d,n/d)的前缀和F(n),n=10^15. [算法]莫比乌斯反演 [题解]参考:任之洲数论函数.pdf 这个范围显然 ...

  5. 20155117王震宇 2006-2007-2 《Java程序设计》第一周学习总结

    20155117王震宇 2006-2007-2 <Java程序设计>第一周学习总结 教材学习内容总结 尽量简单的总结一下本周学习内容 尽量不要抄书,浪费时间 看懂就过,看不懂,学习有心得的 ...

  6. 面试整理(3)js事件委托

    事件委托主要用于一个父容器下面有很多功能相仿的子容器,这时候就需要将子容器的事件监听交给父容器来做.父容器之所以能够帮子容器监听其原理是事件冒泡,对于子容器的点击在冒泡时会被父容器捕获到,然后用e.t ...

  7. Go语言 6 结构体、方法和接口

    文章由作者马志国在博客园的原创,若转载请于明显处标记出处:http://www.cnblogs.com/mazg/ Go学习群:415660935 结构体(struct)是由一系列具有相同类型或不同类 ...

  8. 多维数组的字符依次输出,用python实现

    #-*- coding=utf-8 -*-listm=["s","l","z","x","l",&q ...

  9. php sprintf格式化注入

    URL:http://efa4e2c2b8df4ce69454639f4e3727071652c31167f341a4.game.ichunqiu.com/ 简单的说就是sprintf中%1$\'会将 ...

  10. $FFT$(快速傅里叶变换)

    - 概念引入 - 点值表示 对于一个$n - 1$次多项式$A(x)$,可以通过确定$n$个点与值(即$x$和$y$)来表示这唯一的$A(x)$ - 复数 对于一元二次方程 $$x^2 + 1 = 0 ...