使用Python操作MongoDB
MongoDB简介(摘自:http://www.runoob.com/mongodb/mongodb-intro.html)
MongoDB 由C++语言编写,是一个基于分布式文件存储的开源数据库系统。
MongoDB 将数据存储为一个文档,数据结构由键值对(key=>value)组成,类似于 JSON 对象。
MongoDB 属于NoSQL,NoSQL即Not Only SQL,意思是"不仅仅是SQL",泛指非关系型数据库。
(关系数据库管理系统(RDBMS)与非关系型数据库(NoSQL)之间的区别请见:https://www.cnblogs.com/HuZihu/p/10233242.html)
MongoDB的一些基本术语
| SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
|---|---|---|
| database | database | 数据库 |
| table | collection | 数据库表/集合 |
| row | document | 数据记录行/文档 |
| column | field | 数据字段/域 |
| index | index | 索引 |
| table joins | 表连接,MongoDB不支持 | |
| primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
使用Python操作MongoDB
接下来我们用python来操作MongDB,首先需要安装PyMongo库(pip install pymongo)。
连接MongoDB:
import pymongo
client=pymongo.MongoClient(host='localhost',port=27017)
注:
host为指定的连接服务器的地址,设置为'localhost'代表连接到本地的MongoDB服务上
port为指定的端口,如果不填,默认为27017
查看MongoDB中的所有数据库:
dblist=client.list_database_names()
结果显示现有3个数据库:
['admin', 'config', 'local']
创建或指定数据库:
db=client['HuziHu']
(注:在MongoDB中,数据库只有在内容插入后才会创建)
创建或指定集合:(集合类似于关系型数据库中的表格)
collection=db['Xiaoyugan']
(注:在MongoDB中,集合只有在内容插入后才会创建)
查看指定数据库中的所有集合:
collist=db.list_collection_names()
插入数据:(我们可以自行指定每条数据的id--"_id";如果我们在插入数据时没有指定 _id,那么MongoDB 会为每条数据添加一个唯一的id。)
插入单条数据:insert_one()
yugan={"Name":"Xiaoyugan", "Type":"", "Flavor":"Spicy","Num":,"Comment":"Don\'t like it.Too hot!"}
collection.insert_one(yugan)
注:insert_one()方法返回InsertOneResult对象,该对象包含 inserted_id 属性,它是插入数据的id值。
插入多条数据:insert_many()
yugan=[{"Name":"Xiaoyugan", "Type":"", "Flavor":"Spicy","Num":,"Comment":"Don\'t like it.Too hot!"},
{"Name":"Xiaoyugan", "Type":"", "Flavor":"Sweet","Num":,"Comment":"Don\'t like it.Too sweet!"},
{"Name":"Xiaoyugan", "Type":"", "Flavor":"Fish","Num":,"Comment":"liked it."}]
collection.insert_many(yugan)
注:insert_many()方法返回InsertManyResult对象,该对象包含 inserted_ids 属性,该属性保存着所有插入数据的id值。
查看数据的id值:xx.inserted_id(对于单条数据)
xx.inserted_ids(对于多条数据)
查看指定集合中的所有数据:
for i in collection.find():
print(i)
查询数据:
查询单条数据:find_one(...) ---返回符合查询条件的第一条结果,如果没有符合查询条件的结果,那么返回None
query={"Type":""}
print(collection.find_one(query))
结果:
{'_id': ObjectId('5c330ea47eb8d621f8d0a351'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Fish', 'Num': , 'Comment': 'liked it.'}
查询所有数据:find(...) ---返回符合查询条件的所有结果,如果没有符合查询条件的结果,那么返回None
query={"Type":""}
for i in collection.find(query):
print(i)
结果:
{'_id': ObjectId('5c330ea47eb8d621f8d0a351'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Fish', 'Num': , 'Comment': 'liked it.'}
{'_id': ObjectId('5c330f6e7eb8d621f8d0a355'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Fish', 'Num': , 'Comment': 'liked it.'}
{'_id': ObjectId('5c330f857eb8d621f8d0a359'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Fish', 'Num': , 'Comment': 'liked it.'}
查询条件可以使用修饰符:
|
符号 |
含义 |
语法 |
|
$lt |
小于 |
{field: {'$lt': value} } |
|
$gt |
大于 |
{field: {'$gt': value} } |
|
$lte |
小于等于 |
{field: {'$lte': value} } |
|
$gte |
大于等于 |
{field: {'$gte': value} } |
|
$ne |
不等于 |
{field: {'$ne': value} } |
|
$in |
在范围内 |
{field: {'$in': [ <value1>, <value2> ... <valueN> ]} } |
|
$nin |
不在范围内 |
{ field: { '$nin': [ <value1>, <value2> ... <valueN> ]} } |
|
$and |
和 |
{ '$and': [ { <expression1> }, { <expression2> } , ... , { <expressionN> } ] } |
|
$or |
或 |
{ '$or': [ { <expression1> }, { <expression2> }, ... , { <expressionN> } ] } |
|
$not |
不是 |
{ field: { '$not': { <operator-expression> } } } |
此外,查询还可以使用一些功能符号:
|
符号 |
含义 |
示例 |
示例含义 |
|
$regex |
匹配正则表达式 |
{'name': {'$regex': '^M.*'}} |
name以M开头 |
|
$exists |
属性是否存在 |
{'name': {'$exists': True}} |
name属性存在 |
|
$type |
类型判断 |
{'age': {'$type': 'int'}} |
age的类型为int |
|
$mod |
数字模操作 |
{'age': {'$mod': [5, 0]}} |
年龄模5余0 |
|
$text |
文本查询 |
{'$text': {'$search': 'Mike'}} |
text类型的属性中包含Mike字符串 |
|
$expr |
使用聚合表达式 |
{ '$expr': {'$gt':['$fans_count', '$follows_count']} } |
粉丝数大于关注数 |
对查询条件更多的说明请见官方文档:https://docs.mongodb.com/manual/reference/operator/query/。
限制返回查询结果的条数:limit(...)
query={"Comment":{"$regex":"^Don"}}
for i in collection.find(query).limit(2):
print(i)
结果:
{'_id': ObjectId('5c330d667eb8d621f8d0a34d'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Spicy', 'Num': , 'Comment': "Don't like it.Too hot!"}
{'_id': ObjectId('5c330ea47eb8d621f8d0a34f'), 'Name': 'Xiaoyugan', 'Type': '', 'Flavor': 'Spicy', 'Num': , 'Comment': "Don't like it.Too hot!"}
统计查询结果的条数:count_documents(...)
query={"Type":""}
print(collection.count_documents(query))
对查询结果进行排序:sort(...)
for i in collection.find().sort('Num', pymongo.ASCENDING):
print(i)
注:pymongo.ASCENDING为升序,pymongo.DESCENDING为降序。
更新数据:
更新单条数据: update_one(..., ...) --- 修改符合查询条件的第一条数据
query={'Flavor': 'Spicy'}
newvalue={"Flavor":"Hot"}
collection.update_one(query,{'$set':newvalue})
更新多条数据: update_many(..., ...) --- 修改符合查询条件的所有数据
query={}
newvalue={'Num':1}
collection.update_many(query,{'$inc': newvalue})
注:返回结果是UpdateResult类型,分别调用matched_count和modified_count属性,可以获得匹配的数据条数和影响的数据条数。
一些常用的更新操作符:
|
符号 |
含义 |
|
$rename |
重新命名字典的键 |
|
$set |
设置字典的值 |
|
$unset |
去除字典的键 |
|
$inc |
增加字典的值 |
|
$setOnInsert |
对已有的数据不更新,只插入原本不存在的数据 |
删除数据:
删除单条数据: delete_one(...) --- 删除符合查询条件的第一条数据
删除多条数据: delete_many(...) --- 删除符合查询条件的所有数据
from bson.objectid import ObjectId
collection.delete_many({'_id':{'$gt':ObjectId('5c330f857eb8d621f8d0a359')}})
删除_id大于ObjectId('5c330f857eb8d621f8d0a359')的数据。
注:
删除数据返回的结果都是DeleteResult类型,可以调用deleted_count属性获取删除数据的条数。
delete_many() 方法如果传入的是一个空的查询对象,则会删除集合中所有的文档。
对集合重新命名: rename()
collection.rename('Yu')
删除集合:
collection.drop()
删除数据库:
client.drop_database('HuziHu')
对集合的更多操作可参见官方文档:http://api.mongodb.com/python/current/api/pymongo/collection.html。
使用Python操作MongoDB的更多相关文章
- Python 操作 mongodb 数据库
原文地址:https://serholiu.com/python-mongodb 这几天在学习Python Web开发,于 是做准备做一个博客来练练手,当然,只是练手的,博客界有WordPress这样 ...
- python操作mongodb
# python操作mongodb # 首先,引入第三方模块pymongo,该模块是python用来操作mongodb的 import pymongo # 第二步,设置ip地址,以及表格名称,表格名字 ...
- 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操作三大主流数据库(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 ...
- MongoDB的安装与python操作MongoDB
一.安装MongoDB 因为我个人使用的是windows,就只记录下windows下的安装 1.下载安装 就是官网,下载msi,选个路径安装 2.配置 看见别的地方说需要手动在bin同级目录创建dat ...
- python 操作mongoDB数据库
网上关于python 操作mongoDB的相关文章相对不是很多,并且质量也不是很高!下面给出一个完整的 增删改查示例程序! #!/usr/bin/python # -*- coding: utf-8 ...
- 【转】Python操作MongoDB
Python 操作 MongoDB 请给作者点赞--> 原文链接 这篇文章主要介绍了使用Python脚本操作MongoDB的教程,MongoDB作为非关系型数据库得到了很大的宣传力度,而市面 ...
随机推荐
- cocos creator主程入门教程(八)—— 代码结构
五邑隐侠,本名关健昌,10年游戏生涯,现隐居五邑.本系列文章以TypeScript为介绍语言. 这一篇简单介绍下代码结构,清晰的代码结构更有利于团队对项目的理解和维护. 1.前面我们介绍了一系列基础功 ...
- javascript小记一则:今天在写VS2005——.NET程序时,写的一个JS图片示例案例
源码如下,如遇调试问题,可以找我解决: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...
- 【spring实战第五版遇到的坑】3.1中的例子报错
按照书中的例子,一直做到第3.1章使用JDBC读写数据时,在提交设计的taco表单时,报了如下的异常信息: Failed to convert property value of type java. ...
- centOS7下Spark安装配置
环境说明: 操作系统: centos7 64位 3台 centos7-1 192.168.190.130 master centos7-2 192.168.190.129 slave1 centos7 ...
- 设计模式系列13:模板方法模式(Template Method Pattern)
定义 定义一个操作中的算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤. --<设计模式GoF> UML类图 使用场景 有 ...
- Java 初始化a=2 打印a+++a++为5
这段程序大概这样: public static void main(String[] args){ int a = 2; System.out.println(a+++a++); } 编译后的字节码为 ...
- Umi+Dva搭建Cesium 3D开发环境
umi,中文可发音为乌米,是一个可插拔的企业级 react 应用框架,是蚂蚁金服的底层前端框架,已直接或间接地服务了 600+ 应用,包括 java.node.H5 无线.离线(Hybrid)应用.纯 ...
- 《.NET 进阶指南》读书笔记2------定义不可改变类型
不可改变对象的定义 一个类型的对象在创建后,它的状态就不能再改变,知道它死亡,它的状态一直维持与创建时相同.这时候称该对象具有不可改变性.这样的类型为不可改变类型. 不可改变对象在创建的时候,必须完全 ...
- 使用 Scrapy 爬取股票代码
个人博客: https://mypython.me 源码地址: https://github.com/geeeeeeeek/scrapy_stock 抓取工具:scrapy scrapy 介绍 Scr ...
- 一起学Android之ToggleButton和Switch
本文以一个简单的小例子,简述在Android开发中ToggleButton(开关按钮)和Switch(开关)的简单使用,仅供学习分享使用. 概述 ToggleButton是一个有两种状态(checke ...