MongoDb 学习笔记(一) --- MongoDb 数据库介绍、安装、使用
1、数据库和文件的主要区别
、 数据库有数据库表、行和列的概念,让我们存储操作数据更方便 、 数据库提供了非常方便的接口,可以让 nodejs、php java .net 很方便的实现增加修改删除功能。
2、NoSql 介绍
2.1 NoSQL 介绍
2.2 NoSQL 应用情况介绍
国内的互联网蓬勃发展,不仅涌现出 BAT(百度,阿里巴巴,腾讯)之类的巨头,也带动了整个互联网行业的发展,大量的创业型公司如春笋般的涌出,在国家层面也提出了“互联网+”和“万众创业”的口号。更多传统的行业也开始拥抱互联网。但是无论是做所谓的生态平台还是传统业务的转型,涉及到的业务是多种多样的。这个时候企业架构师对于应用系统的核心——数据库管理 不仅有传统的 SQL 选项也有了NoSQL 这种适合特定场景需求的选项。
NoSQL 数据库在以下的这几种情况下比较适用:
、数据模型比较简单; 、需要灵活性更强的 IT 系统; 、对数据库性能要求较高; 、不需要高度的数据一致性; 、对于给定 key,比较容易映射复杂值的环境。
NoSQL 发展现状
国外: Google 的 BigTable 和 Amazon 的 Dynamo 使用的就是NoSQL 型数据库。 国内: 百度、阿里、腾讯、新浪微博、视觉中国、优酷运营数据分析、飞信空间、豆瓣社区等..
3、什么时候建议使用 NoSql
、对数据库高并发读写的需求 、对海量数据的高效率存储和访问的需求 、对数据库的高可扩展性和高可用性的需求 、NoSql 和传统数据库简单对比。
4、NoSql 和传统数据库简单对比
、非结构型数据库。没有行、列的概念。用 JSON 来存储数据。 、集合就相当于“表”,文档就相当于“行”。

5、NoSql 种类

6、MongoDb 介绍
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似 json 的 bson 格式,因此可以存储比较复杂的数据类型。Mongo 最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。它的特点是高性能、易部署、易使用,存储数据非常方便。
MongoDB是开源,高性能的NoSQL数据库;支持索引、集群、复制和故障转移、各种语言的驱动程序丰富;高伸缩性;
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。shell命令操作语法和JavaScript很类似,其实控制台底层的查询语句都是用JavaScript脚本完成操作的。
主要特点
- MongoDB的提供了一个面向文档存储,操作起来比较简单和容易。
- 你可以在MongoDB记录中设置任何属性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")来实现更快的排序。
- 你可以通过本地或者网络创建数据镜像,这使得MongoDB有更强的扩展性。
- 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
- Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
- MongoDb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
- Mongodb中的Map/reduce主要是用来对数据进行批量处理和聚合操作。
- Map和Reduce。Map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给Reduce函数进行处理。
- Map函数和Reduce函数是使用Javascript编写的,并可以通过db.runCommand或mapreduce命令来执行MapReduce操作。
- GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
- MongoDB允许在服务端执行脚本,可以用Javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
- MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
- MongoDB安装简单。
7、MongoDb 安装
手册:https://docs.mongodb.org/manual/
github: https://github.com/mongodb/
nodejs驱动:https://github.com/mongodb/node-mongodb-native
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

7.1 下载地址
https://www.mongodb.com/download-center/v2/community


7.3 添加到path环境变量中
如何添加环境变量 https://jingyan.baidu.com/article/b24f6c82cba6dc86bfe5da9f.html

7.4 创建数据目录
MongoDB将数据目录存储在 db 目录下。但是这个数据目录不会主动创建,我们在安装完成后需要创建它。请注意,数据目录应该放在根目录下((如: C:\ 或者 D:\ 等 )。
在本案例中,我在 C 盘安装了 mongodb,现在我在C盘创建一个 data 的目录然后在 data 目录里创建 db文件和log文件。

7.5 命令行下运行 MongoDB 服务器
打开cmd
windows+ R

输入
mongod --dbpath c:\data\db

7.6 连接MongoDB
mongo

7.7 配置 MongoDB 服务
创建配置文件
创建一个配置文件位于 C:\Program Files (x86)\mongodb\mongod.cfg,其中指定 systemLog.path 和 storage.dbPath。具体配置内容如下:
systemLog:
destination: file
path: c:\data\log\mongod.log
storage:
dbPath: c:\data\db

安装 MongoDB服务
通过执行mongod,使用--install选项来安装服务,使用--config选项来指定之前创建的配置文件。
mongod --config "C:\Program Files (x86)\mongodb\mongod.cfg" --install
启动MongoDB服务
net start MongoDB

关闭MongoDB服务
net stop MongoDB

8、MongoDb 使用
显示所有数据库
show dbs
使用数据库
use xxx

MongoDb 学习笔记(一) --- MongoDb 数据库介绍、安装、使用的更多相关文章
- MongoDB 学习笔记(一):安装及简单shell操作
		一.说明 1.该系列MongoDB学习笔记的学习环境采用的MongoDB版本为mongodb-win32-i386-2.4.6,操作系统为win7. 二.安装 1.新建两个目录,分别是D:\Insta ... 
- Mongodb学习笔记一(Mongodb环境配置)
		Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ... 
- MongoDB学习笔记(一) MongoDB介绍及安装(摘)
		MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/值存储方式.Mongo使用C++开发.Mongo的官方网 ... 
- MongoDB学习笔记一(MongoDB介绍 + 基本指令 + 查询语句)
		什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供可扩 ... 
- Mongodb学习笔记二(Mongodb基本命令)
		第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ... 
- Mysql的学习笔记(一)--检验数据库是否安装成功以及一些入门的简单的dos命令
		一:如何检验数据库是否安装成功: 1:以管理员的身份打开命令提示符,具体如何用管理员的身份打开请参考下面 https://jingyan.baidu.com/article/e73e26c0f87c2 ... 
- mysql学习笔记之mysql数据库的安装
		1.执行mysql安装包选择自己定义安装(安装路径不要带中文,否则安装会出错! ) 2.一个mysql想要操作成功须要有三部分:server端,数据段,数据. 3.server软件文件夹: 4.数据文 ... 
- MongoDB学习笔记(一) MongoDB介绍及安装
		转自:http://database.51cto.com/art/201103/247882.htm http://baike.baidu.com/link?url=b6B3dVSCnQauCX-Ep ... 
- MongoDB学习笔记二:使用Docker安装MongoDB
		目录 Docker安装MongoDB Docker给MongoDB设置用户密码 NoSQL Manager for MongoDB连接 为admin赋权限 上一个笔记介绍了Windows下安装Mong ... 
随机推荐
- 趣图:当我捕获Bug的时候
			趣图:当我以为已捕获了所有可能的异常...的时候 趣图:程序员调 Bug 的感觉,就是这样的 
- NVIDIA | 一种重建照片的 AI 图像技术
			简评:或许可以称之为「擦擦乐」~ 建议大家看看视频示例 ~ 前几天,NVIDIA 的研究人员介绍了一种新的 深度学习 方法,使用该方法可以重建缺失像素的图像内容. 这种方法被称为「image inpa ... 
- PL/SQL数据库开发那点事
			PL/SQL数据库开发那点事-->编程,存储程序 在SQL*plus 中编写PL/SQL程序,并在SQL*plus 中执行它, PL/SQL块的代码就存放在SQL*plus的缓冲区中.如果在SQ ... 
- 2018年10月19 手记 - 身为开发者的我de窘境
			从10月1国庆过完节回来,那已经是7号了,之后便开始紧锣密鼓的筹划着接下来11月份的公司组织的对外活动,这边新来的产品对产品或者说对任务很是负责,并且策划了很多的方案,并且乐意站在我们开发的角度上去考 ... 
- 前端统计图   echarts  实现简单柱状图
			前端统计图 echarts实现简单柱状图 1. 引入 ECharts <!DOCTYPE html> <html> <head> <meta charse ... 
- [CQOI2015]标识设计
			Luogu3170 128MB过不去 LOJ2099 256MB能卡过 BZOJ3934 512MB怎么都过的去 求在\(30*30\)的方格上放\(3\)个\(L\)的方案 , 有障碍 拓展这条路的 ... 
- [BZOJ 5158][Tjoi2014]Alice and Bob
			传送门 \(\color{green}{solution}\) 贪心 /************************************************************** P ... 
- 本地DataGrip连接阿里云MySQL
			1.阿里云上开通MySQL端口 2.MySQL上的设置 1⃣️mysql -uroot -p2⃣️create user 'usrabc'@'%' identified by 'usrabc'; 3. ... 
- Ubuntu16.04+Cuda8.0+cuDNN6配置py-faster rcnn(转)
			原博客地址:https://blog.csdn.net/meccaendless/article/details/79557162 0前言Faster R-CNN是任少卿2015年底推出的目标检测算法 ... 
- CDH集群安装配置(三)- 集群时间同步(主节点)和 免密码登录
			集群时间同步(主节点) 1. 查看是否安装ntp服务,如果没有安装 rpm -qa |grep ntpd查看命令 yum install ntp安装命令 2. 修改配置 vi /etc/ntp.con ... 
