一 NoSQl简介
NoSQL(NoSQL = Not Only SQL),意即反 SQL 运动,指的是非关系型的数据库,是一项全新的数据库革命性运动,早期就有人提出,发展至2009年趋势越发高涨。NoSQL 的拥护者们提倡运用非关系型的数据存储,相对于目前铺天盖地的关系型数据库运用,这一概念无疑是一种全新的思维的注入。
1 为什幺使用 NoSQL
-
对数据库高并发读写。
-
对海量数据的高效率存储和访问。
-
对数据库的高可扩展性和高可用性。
2 弱点
-
数据库事务一致性需求
-
数据库的写实时性和读实时性需求
-
对复杂的 SQL 查询,特别是多表关联查询的需求
二 什么是 MongoDB
MongoDB 是由 C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值( key => value )对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
三 MongoDB 特点
1 MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
2 你可以在 MongoDB 记录中设置任何属性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")来实现更快的排序。
3 你可以通过本地或者网络创建数据镜像,这使得 MongoDB 有更强的扩展性。
4 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上,这就是所谓的分片。
5 Mongo支持丰富的查询表达式。查询指令使用 JSON 形式的标记,可轻易查询文档中内嵌的对象及数组。
6 MongoDb 使用 update() 命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
7 Mongodb 中的 Map/reduce主要是用来对数据进行批量处理和聚合操作。
8 Map 和 Reduce。Map 函数调用 emit(key,value) 遍历集合中所有的记录,将 key 与 value 传给 Reduce 函数进行处理。
9 Map 函数和 Reduce 函数是使用 Javascript 编写的,并可以通过 db.runCommand 或 mapreduce 命令来执行 MapReduce 操作。
10 GridFS 是 MongoDB 中的一个内置功能,可以用于存放大量小文件。
11 MongoDB 允许在服务端执行脚本,可以用 Javascript 编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
12 MongoDB 支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
13 MongoDB安装简单。
四 安装 mongodb
#拉取镜像
docker pull mongo:latest
#创建和启动容器
docker run -d --restart=always -p 27017:27017 --name mymongo -v /data/db:/data/db -d mongo
#进入容器
docker exec -it mymongo /bin/bash
#使用MongoDB客户端进行操作
mongo
> show dbs #查询所有的数据库
admin 0.000GB
config 0.000GB
local 0.000GB
五 百度网盘下载
一、mongoDB window64 百度网盘资源下载,及安装教程_DreamFive-CSDN博客_mongodb 百度网盘