MongoDB 简介

一 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 百度网盘

六 安装排错方法

启动MongoDB服务器时出现代码:错误1053【已解决】 - 啊斗哇 - 博客园

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值