0 之前我们maogoDB用的是在线的mlab

在线他们帮我们做好了model 也就是那个schma

其实python也有类似的包 帮我们定义这些model

但是呢

我们自己来做吧

用一个传统的意义上mongoDB 就是 insert select来操作数据库

就是在不用其他类库 定义的model

我们如何操作数据库

我们这次用本地mongoDB

因为我们以后要做网络爬虫

这么爬下来的数据都会放在mongoDB里面储存

会很多 如果我们用mlab 那么将来把数据导出的时候就很不方便

所以 建议部署在本地

用法其实和mlab没啥区别

去官网https://docs.mongodb.com/manual/tutorial/install-mongodb-on-ubuntu/

安装提示4步安装

当然也可以直接下载下来 解压缩安装

都可

第三种方法(我安装的这个,我是因为网络原因)

https://www.howtoing.com/how-to-install-mongodb-on-ubuntu-18-04

安装完成

新版本执行下面命令

因为是按第三种 安装的老版本的所以我的start命令不一样 具体看https://www.howtoing.com/how-to-install-mongodb-on-ubuntu-18-04

sudo systemctl start mongodb

本地mangodb自带工具mongo

显示现有的数据库

切换数据库

数据库有很多表(collections)

use这个命令除了可以切换数据库 还能创建数据库 如果有就切换到 没有就创建

但是如果你没插数据进去 他不会创建 必须有数据

我们现在弄点数据倒进数据库 插两条条数据

我们发现insert只能插一条,一条一条的插

我们再来一条

这里有个导入导出数据方便的工具 注意再是CMD命令行里面打命令 并不是在mongo shell里面

mongoexport

mongoimport --db tap-news --collection news --drop week6_demo_news.json

导入数据到数据库 并制定导入数据文件名称

drop是存在的话 就替代

mongoexport --db tap-news --collection news --out week6_demo_news.json

从数据库导出数据并命名

如何删除数据库

use +数据库名  切换到某个数据库然后执行

db.dropDatabase删除数据库

下面使用python操作mongodb

安装一个库 为了以后别人方便安装 我们写到一个配置文件里面

我们这个pymongo想单独独立出来 谁用 就来调用就行了

所以我们

创建工具文件夹

主要为了复用方便(解耦)

这个MongoClien类t实现了维持一个连接数为10的连接池(为了数据库性能)

这样保证了单例模式

不管有多少模块import我们这个client 自始至终我们只有一个连接连接到mongodb

增删改查可以在这定义函数

下面我们去测试吧

看能不能连上数据库

新建一个测试文件

大小写敏感

那么我们改一下看看

然后 我们将注释放开再看看

发现demo(collections)木有了 drop了

这验证了可以client操作数据库

week6 10 后端backend server和mongoDB通信的更多相关文章

  1. 第 10 章 MySQL Server 性能优化

    前言: 本章主要通过针对MySQL Server(mysqld)相关实现机制的分析,得到一些相应的优化建议.主要涉及MySQL的安装以及相关参数设置的优化,但不包括mysqld之外的比如存储引擎相关的 ...

  2. ArcGIS 10.3 for Server新特性介绍

    ArcGIS10.3的正式版立即在美国Esri全球用户大会推出.中国的正式发行时间预计在Esri中国的用户大会.以下就将用户比較关心的ArcGIS 10.3 for Server的新特性给大家进行简单 ...

  3. 【转】ArcGIS 10.1 for Server 架构

    前一段时间在博客中公布了我们的计划,我们采用博客的形式将对ArcGIS10.1 for Server进行全面介绍.但这种形式有一定的遗憾:缺少互动的空间,所以我们希望广大爱好者能将自己感兴趣的话题在博 ...

  4. 【ArcGIS 10.2新特性】ArcGIS 10.2 for Server常见问题

    1.ArcGIS 10.2有无测试版程序? 10.2没有正式的测试版程序,但是我们计划发布两个早期cuts软件给国际经销商.选中的用户和合作伙伴. 2.微软Azure云的ArcGIS forServe ...

  5. 【ArcGIS 10.2新特性】ArcGIS 10.2 for Server新特性

    ArcGIS forServer相关的很多重大消息,如与Portal for ArcGIS进行了集成,提供对实时数据支持.离线地图使用. 1.与Portal for ArcGIS集成 用户能够配置Po ...

  6. ArcGIS 10.1 for Server 扩展开发(SOE)

    原文连接:http://blog.csdn.net/arcgisserver_book/article/details/7869368 第一章为什么使用SOE 在ArcGIS 10.1中ArcGIS ...

  7. Ubuntu 16.10 Apache PHP Server

    /******************************************************************************************* * Ubunt ...

  8. ArcGIS 10.1 for Server安装教程系列—— Linux下的单机安装

    http://www.oschina.net/question/565065_81231      因为Linux具有稳定,功能强大等特性,因此常常被用来做为企业内部的服务器,我们的很多用户也是将Ar ...

  9. ArcGIS 10.3 for Server 在windows下的安装教程

    原文:ArcGIS 10.3 for Server 在windows下的安装教程 以下是10.2的教程,10.3同样适用. 许可文件: ArcGIS For Server10.3许可文件 - 下载频道 ...

随机推荐

  1. nonlocal和global

    获取变量时遵循LEGB原则,修改变量时需要global/nonlocal进行修改 global # global的使用 函数外定义了全局变量: global关键字在函数内会修改全局变量 函数外没定义全 ...

  2. 02-创建String对象

    创建一个String对象实在是太简单了,就是因为简单,所以有很多java程序员做了好几年的开发,也没有注意这些小细节问题 String字符串的本质就是char数据对象, 那么char[0]数组当中的一 ...

  3. spark使用hadoop native库

    默认情况下,hadoop官方发布的二进制包是不包含native库的,native库是用C++实现的,用于进行一些CPU密集型计算,如压缩.比如apache kylin在进行预计算时为了减少预计算的数据 ...

  4. 9 个鲜为人知的 Python 数据科学库

    除了 pandas.scikit-learn 和 matplotlib,还要学习一些用 Python 进行数据科学的新技巧. Python 是一种令人惊叹的语言.事实上,它是世界上增长最快的编程语言之 ...

  5. 「HNOI2015」开店(树链剖分, 主席树)

    /* 考虑将所求的值拆分 记每个点到根的路径长度为dis_i, 那么我们要求的就是\sum_{i = l} ^ r dis_i + dis[u] * (r - l + 1) - 2\sum_{i = ...

  6. 编码,基本数据类型,str索引和切片,for循环

    1. 编码 1. 最早的计算机编码是ASCII. 美国人创建的. 包含了英文字母(大写字母, 小写字母). 数字, 标点等特殊字符!@#$% 128个码位 2**7 在此基础上加了一位 2**8 8位 ...

  7. mogoDB工具选择及连接<一>

    最近在某微服务项目中需要用到mogoDB 原因是:开源免费.适合互联网公司.大数据量情况下性能比mysql好 咨询过为啥不用oracle,原因你懂得 --费用 好,言归正传: 1.选择工具,使用工具是 ...

  8. SVG 学习<四> 基础API

    目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...

  9. getpass模块 ---- optparse

    getpass模块,不回显 常用方法 import getpass password=getpass.getpass('input your password: ').strip() 其他用法 use ...

  10. python-多线程和线程池

    import threading # 点击查看它的用法 传统多线程方案会使用“即时创建, 即时销毁”的策略. from multiprocessing.dummy import Pool # 线程池 ...