前言:

MongoDB,文档存储型数据库(document store)。NoSQL数据库中,它独占鳌头,碾压其他的NoSQL数据库。

使用C++开发的,性能仅次C。与redis一样,开源、高扩展、高可用。

基于分布式文件存储。分布式:文件分开存的(由Google提出的mapreduce,是目前分布式的鼻祖)。就像苹果的iCloud,照片、文件分开存储的。

纽约时报用的数据库就是它(from wiki),360部分业务的数据库也是它。而且据说伟大的wiki,也是从曾经的MySQL迁移到了MongoDB。

MongoDB的适用场景可以看下这篇文章:https://yq.aliyun.com/articles/64352

但要注意,MongoDB在使用过程中会消耗大量磁盘空间和内存。而且,MongoDB它非事务机制,无法保证事件的原子性。

MongoDB不适合的场景:

(1).需高度事务性的系统。当原子性操作失败时,传统的关系型数据库支持回滚操作,以保证数据在操作过程中的正确性。而目前,MongoDB暂不支持此事务。例如银行或会计系统。

(2).传统的商业智能应用。针对特定问题的BI数据库需要高度优化的查询方式。

(3).使用SQL方便时(关联查询)。MongoDB的查询方式是JSON类型的查询方式,虽然查询也比较灵活,但如果使用SQL进行统计会比较方便时,这种情况就不适合使用MongoDB。

MongoDB描述、层次结构:

(一).描述

MongoDB是文档数据库,以文档为单位。Bson文档(Json的二进制)

与JS相关,内部引擎用了JS解释器。

把一个文档存储为Bson结构,在查询时,转换位Json对象,并可以通过JS语法来操作。

(二).层次结构

库 -> 集合 -> 文档

MongoDB PK 传统型数据库:

传统型数据库:结构化数据,定好表结构后,每一行内容必须符合表结构,以至于每一行看起来都长得差不多。

MongoDB:以文档为单位,没有表结构。表中的每篇文档都可以有自己独特的属性和结构。

MongoDB最大的特点就是反范式化,管你几张表,都可以一个文档解决。每个文档相当于一棵树,可以无限伸枝。文档与文档之间相互独立,没有固定的结构。

(一).文档的表现形式:一个Json对象,一个文档

# 一个文档
{id: 3name: "lisi"age: 10
}# 另一个文档
{id: 4name: "wangwu"age: 20area: "nb"hobby: ["swimming", "football"]
}

View Code

(二).思考这么一个问题:

以此https://movie.douban.com/subject/26861685/?from=showing为例,设计一个影评数据库。

传统数据库:影片信息一张表,影评一张表,回复评论一张表,打分一张表。查询起来相当费劲,关联相当复杂。

MongoDB:上述内容全部丢进一个文档中解决:

{file_name: "红海行动"long_time: 120comment: [{comment1: "影评1"reply1: "好评"}]
}

View Code

一、install MongoDB for win7 32bit(万事从安装开始)

悲催的win7 32位系统,安装MongoDB可是受尽折磨,不是执行命令后没反应、就是因为32/64位的问题……

好在运气不错,找到了这篇文章:https://www.cnblogs.com/chenyucong/p/6217017.html 此博主提供了一个版本,本人跟着操作也行了。

直接照着那篇搞就可以:(配置命令去复制就可以了,自己敲会出错,而且配置一次就完事了,又不是非要掌握的)

第一步操作成功:MongoDB的默认端口为27017

第二步配置:(注意环境变量的路径大小写,第一次没成功,后来直接在地址栏上复制了路径,成了!所以猜测,可能是因为路径大小写问题造成)

有时候电脑会抽风,即使配置好了环境变量,在C盘盘符下打这串命令会提示不是内部命令。那么直接cd进入mongodb/bin目录,再执行这条命令,就行了。

可在系统服务中看到它了:

相对现在的新版本,这个算是很老的版本了,不过学习用应该是够了。

MongoDB使用内存映射文件,32位系统上,数据库容量最大上限为2G,关于这个内存映射文件,不了解也没关系,影响不大。找来了伟大的wiki:https://zh.wikipedia.org/wiki/%E5%86%85%E5%AD%98%E6%98%A0%E5%B0%84%E6%96%87%E4%BB%B6

第三步:搞一个可视化管理工具

本来想用Robomongo(因为它界面很好看),但没找到适用于win7 32位系统的[/喷血]。如有大大找到的话,恳请提供。

现在在用MongoVUE,专门用于windows系统的。填写连接卡的时候,最后下面三个不填也可以连上。Name随便写,可以写你喜欢的人的名字;Server:具体情况具体填,可以填一个远程主机的IP;Database(s)这项不填,就会获得所有数据库。

二、install MongoDB on Ubuntu server

(一).简易安装

ubuntu server的apt秒天秒地,更新好apt之后直接键入命令:apt install mongodb

安装完后,想要查看版本可用命令:mongo -version

用apt命令直接安装不会是最新版本,最好去官网https://www.mongodb.com/download-center/community下载进行源码安装。

(二).源码安装

(三).在ubuntu server中的更新MongoDB

sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 0C49F3730359A14518585931BC711F9BA15703C6

echo "deb http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.4 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.4.list

sudo apt-get updatesudo apt-get install -y mongodb-orgsystemctl unmask mongodbservice mongodb start

View Code

这些操作后,MongoDB依然不会是最新版本,想要最新版去官网下载并进行源码安装。

三、MongoDB原生态命令

(一).插入文档

命令格式:db.collection_name.insert()小括号里写json

例如:

db.biancheng.insert({name:"yekai",age:35,sex:"man",info:{like:"drink",wuqi:"feidao"}})

View Code

(二).更新文档

(1).只更新指定的数据

db.collection_name.update({查询条件json},{$set:{新数据json1,新数据json2,...}})

例如:

db.biancheng.update({name:"yekai"},{$set:{name:"yekai1",age:40}})

View Code

四、python3操作MongoDB

(一).连接localhost server,创建一个新数据库

注意:MongoDB的默认端口号是27017,跟其他数据库一样,创建连接时要写上。

from pymongo import MongoClientconn = MongoClient("localhost", 27017)# 也可以写成
# conn = MongoClient("mongodb://localhost:27017")

db = conn.testdb  # 创建数据库

conn.close()

View Code

MongoDB不需要提前创建好数据库,可以直接"连接对象.数据库名称"。如果没有这个数据库,则会自动创建。如果有这个数据库了,就会连接上。

但是,如果该数据库中没有数据,则不会显示在管理工具里面。

(二).增。

(1).插入单个文档

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdb# db = MongoClient("localhost", 27017).testdb
# 这样写的话,后面数据库连接就没法关闭了。所以别偷懒,还是要分开写。

db.col.insert({"name": "quanquan616", "province": "浙江", "age": 30})  # col是表名

conn.close()

View Code

(2).插入多个文档

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbdb.col.insert([{"name": '张三', 'province': '浙江', 'age': 24},{"name": 'yuanyuan', 'province': '山东', 'age': 24},{"name": 'jt', 'province': '陕西', 'age': 30}
])conn.close()

View Code

总结:插入多个文档,insert()的括号中,需要用[]把元素包裹起来。insert([{},{},{}])

(三).删。特别注意:remove()括号中不加条件,就会把表中的记录全删了!切记注意!不然得赔80个亿,跳海喂鲨鱼去吧……

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbdb.col.remove({"name": "张三"})conn.close()

View Code

(四).改。update({条件},{更新的数据})

把条件和更新的数据放进去update()的括号里就可以了。更新语句,注意格式别写错了,应该是{"$set":{"key":value}}

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbdb.col.update({"name": "quanquan616"}, {"$set": {"age": 29}})conn.close()

View Code

(五).查。

(1).使用find_one()查询并返回第一个匹配到的文档

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbdb.col.find_one()conn.close()

View Code

可以把"db.col.find_one()"放在print()中,这样就可以看到打印出来的查询结果了。print()之后的结果:{'_id': ObjectId('5a924d0f36af002d307cc30b'), 'name': 'quanquan616', 'province': '浙江', 'age': 30}

这个'_id':ObjectId('xxxxxxxxx')是自动生成的唯一值。

db.col.find_one({"name":"abc"}) 没有找到文档则返回None

(2).查询所有记录。可以使用find()函数,执行后返回的是一个结果集对象,需要用for循环遍历出来。

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdb# print(db.col.find())  # <pymongo.cursor.Cursor object at 0x01D96210>for item in db.col.find():print(item)conn.close()"""
# 远行结果:
{'_id': ObjectId('5a924d0f36af002d307cc30b'), 'name': 'quanquan616', 'province': '浙江', 'age': 30}
{'_id': ObjectId('5a92520f36af001ca0fb665c'), 'name': '张三', 'province': '浙江', 'age': 24}
{'_id': ObjectId('5a92520f36af001ca0fb665d'), 'name': 'yuanyuan', 'province': '山东', 'age': 24}
{'_id': ObjectId('5a92520f36af001ca0fb665e'), 'name': 'jt', 'province': '陕西', 'age': 30}
"""

View Code

(3).条件查询

只需要将条件当作参数放进find()的括号中即可:

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbfor item in db.col.find({"name": "quanquan616"}):print(item)conn.close()

View Code

例1:查询所有小于某个值的记录

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbfor item in db.col.find({"age": {"$lt": 25}}):print(item)conn.close()"""
运行结果:
{'_id': ObjectId('5a92520f36af001ca0fb665c'), 'name': '张三', 'province': '浙江', 'age': 24}
{'_id': ObjectId('5a92520f36af001ca0fb665d'), 'name': 'yuanyuan', 'province': '山东', 'age': 24}
"""

View Code

补充:大于的话,就把{"age":{"$lt":25}}中的lt换成gt

(4).统计记录

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbdb.col.find({"age": {"$eq": 30}}).count()  # 返回int,但不会直接显示结果,需要赋值变量或者打印
# print(db.col.find({"age": {"$eq": 30}}).count())  # 2

conn.close()

View Code

(5).根据_id查询记录

需要引入一个库,这个库python3自带了。from bson.objectid import ObjectId

from pymongo import MongoClient
from bson.objectid import ObjectIdconn = MongoClient("localhost", 27017)
db = conn.testdb# ObjectId是唯一的,所以用find_one()就可以了
db.col.find_one({'_id': {ObjectId('5a924d0f36af002d307cc30b')}})
# print(db.col.find_one({'_id': ObjectId('5a924d0f36af002d307cc30b')}))
# {'_id': ObjectId('5a924d0f36af002d307cc30b'), 'name': 'quanquan616', 'province': '浙江', 'age': 30}

conn.close()

View Code

(6).排序。MongoDB默认升序排序。

sort()小括号中放入指定的key就可以了:

from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbfor item in db.col.find().sort("age"):print(item)conn.close()"""
运行结果:
{'_id': ObjectId('5a92520f36af001ca0fb665c'), 'name': '张三', 'province': '浙江', 'age': 24}
{'_id': ObjectId('5a92520f36af001ca0fb665d'), 'name': 'yuanyuan', 'province': '山东', 'age': 24}
{'_id': ObjectId('5a924d0f36af002d307cc30b'), 'name': 'quanquan616', 'province': '浙江', 'age': 30}
{'_id': ObjectId('5a92520f36af001ca0fb665e'), 'name': 'jt', 'province': '陕西', 'age': 30}
"""

View Code

另外,可以加入参数去设定排序方式。

比如倒序,例1:(需要引入pymongo)

import pymongo
from pymongo import MongoClientconn = MongoClient("localhost", 27017)
db = conn.testdbfor item in db.col.find().sort("age", pymongo.DESCENDING):  # descending降序print(item)conn.close()

View Code

(六).补充内容

(1).删除一张表:db.drop_collection("table_name") 表和其中的数据同时删除

(2).查看一个数据库中所有的表:db.collection_names()

转载于:https://www.cnblogs.com/quanquan616/p/8463567.html

NoSQL-MongoDB with python相关推荐

  1. MapReduce with MongoDB and Python[ZT]

    MapReduce with MongoDB and Python 从 Artificial Intelligence in Motion 作者:Marcel Pinheiro Caraciolo ( ...

  2. NoSQL——MongoDB

    2019独角兽企业重金招聘Python工程师标准>>> NoSQL--MongoDB 一.MongoDB介绍 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为 ...

  3. mongodb和python交互

    mongodb和python交互 1. mongdb和python交互的模块 pymongo 提供了mongdb和python交互的所有方法 安装方式: pip install pymongo 2. ...

  4. 基于 MongoDB 的 python 日志功能

    本文首发于 Gevin的博客 原文链接:基于MongoDB的python日志功能 未经 Gevin 授权,禁止转载 基于MongoDB的python日志功能 why-log-to-mongodb 我几 ...

  5. MongoDB 和 Python 不通用的操作

    具体操作 Mongodb SQL Python 空值操作 db.getCollection('example _data_2').find({'grade': null}) rows = collec ...

  6. MongoDB与python 交互

    一.安装pymongo 注意 :当同时安装了python2和python3,为区分两者的pip,分别取名为pip2和pip3. 推荐:https://www.cnblogs.com/thunderLL ...

  7. 三、mongodb数据库系列——mongodb和python交互 总结

    一.mongodb和python交互 学习目标 掌握 mongdb和python交互的增删改查的方法 掌握 权限认证的方式使用pymongo模块 1. mongdb和python交互的模块 pymon ...

  8. python做前端mongodb_Python爬虫之mongodb和python交互

    mongodb和python交互 学习目标 掌握 mongdb和python交互的增删改查的方法 掌握 权限认证的方式使用pymongo模块 1. mongdb和python交互的模块 pymongo ...

  9. 微软ASP.NET 电商网站开发实战 MVC6 +HTML5 +WCF+WebAPI+NoSQL+mongoDB+Redis+Core视频 代码 面试题...

    <微软ASP.NET 电商网站开发实战 MVC6 +HTML5 +WCF+WebAPI+NoSQL+mongoDB+Redis+Core 视频 代码 面试题 >下载网盘:https://y ...

  10. Python爬取豆瓣音乐存储MongoDB数据库(Python爬虫实战1)

    Python爬取豆瓣音乐存储MongoDB数据库(Python爬虫实战1) 1.  爬虫设计的技术 1)数据获取,通过http获取网站的数据,如urllib,urllib2,requests等模块: ...

最新文章

  1. html判断数字数据的大小写,判断一个字符是否是数字、还是大小写字母
  2. paip.按键替换映射总结
  3. web服务枚举组件不可用
  4. DeepMedic —— 一种经典的医学图像分割的3D CNN框架
  5. cv2 python3.5 linux,ubuntu 16.04 安装 opencv3.2.0 with python 3.5
  6. 西门子v90伺服说明书_干货 | 西门子1200与V90伺服PROFINET通信故障解决方法
  7. SQL SERVER数据类型与C#数据类型对照表
  8. 百度OCR文字识别API使用心得===com.baidu.ocr.sdk.exception.SDKError[283604]
  9. 关于重构中的“函数尽量小”的负作用
  10. 分治法 —— 快速排序和归并排序(自底向上和自顶向下)
  11. HTML—讲解分割线标签、文字居中、背景图片充满全图
  12. nodejs操作redis总结
  13. 第26讲 js函数调用过程内存分析 js函数细节
  14. oracle 11.2 awr,oracle 11g database获取AWR报告
  15. Mac安装JDK1.8及环境变量配置
  16. 三段式状态机原理详细解释
  17. 可视化图布局算法浅析
  18. html中form异步验证,form表单验证
  19. 转:python中range和xrange的区别
  20. c语言数据结构课程设计停车场管理系统,数据结构课程设计报告停车场管理系统...

热门文章

  1. 对Android源码分析总结(Z)
  2. python文本结构化处理_在Python中标记非结构化文本数据
  3. android 揭示动画_遗传编程揭示具有相互作用的多元线性回归
  4. 月收入两千,负债40万,怎么来处理?
  5. 定时执行 Job - 每天5分钟玩转 Docker 容器技术(135)
  6. 信用卡申请被拒原因分析
  7. 为知笔记:优秀国产知识管理软件的使用心得
  8. 如何使用oprofile对软件做profiling
  9. 压力测试过负载均衡_性能测试的方法有哪些?
  10. gc java root_聊聊Java的GC机制