MongoDB实战之快速开始

写在前面:以前使用mongo只了解了个增删改查,而且没有集成springboot里面使用过。最近花了几小时系统的学习了一遍MongoDB,为了巩固和方便查找,在此记录下学习过程。

一、MongoDB的简介

MongoDB 是一个高性能、高可用性和易扩展的 NoSQL 数据库。与传统的关系数据库(如 MySQL 或 PostgreSQL)相比,MongoDB 使用 JSON-like 的文档格式(BSON)来存储数据,这使得数据模型更为灵活。

主要特点:

  1. 文档导向:MongoDB 存储的数据是 BSON(二进制 JSON)文档,具有动态模式,这意味着文档中可以嵌套其他文档和数组。

  2. 高性能:因为其内存数据存储和优化的查询性能,MongoDB 提供了高速读写操作。

  3. 高可用性:通过副本集(Replica Sets)实现数据的高可用性。

  4. 水平扩展:MongoDB 可以通过分片(Sharding)在多台机器上分布数据,以支持非常大的数据集。

  5. 丰富的查询语言:MongoDB 提供了一组丰富的查询操作和索引,让你能够方便地搜索、排序和过滤数据。

  6. 支持地理空间数据:你还可以用它进行地理空间查询。

  7. 开源:MongoDB 是开源软件,任何人都可以下载和使用,也有多种商业版本提供额外的功能和支持。

用途:实时分析和数据可视化、移动应用、内容管理系统、IoT 应用、电子商务等。

上面提到了一个BSON,什么是BSON?

BSON(Binary JSON 的缩写)是一种二进制编码的序列化 JSON-like 文档的格式。MongoDB 使用 BSON 作为数据存储和网络传输的格式。BSON 不仅支持 JSON 常见的数据类型(例如数值、字符串和布尔值),还支持更多复杂的类型,如日期和二进制数据。

BSON 的主要特点:

  1. 类型丰富 :除了基本的 JSON 类型(字符串、数值、数组、对象、布尔值、null)之外,BSON 还支持其他几种数据类型,包括日期和二进制数据。

  2. 轻量级:虽然 BSON 比纯 JSON 略大,但它仍然是一个非常轻量级的存储格式。

  3. 高效:BSON 格式设计成易于扫描和解析,这有助于提高 MongoDB 的读写性能。

  4. 可遍历:由于其结构化的格式,BSON 文档可以被快速遍历,这对于数据库查询操作是非常有用的。

  5. 支持内嵌文档和数组:这让数据更加灵活和多层次,非常适合文档导向的数据库模型。

个人理解:浅显看就是JOSN的加强版,传输形式还是JSON的{key:value}形式,mongo拿到这个之后,key就作为了字段名,value就作为了值。

二、安装与搭建

快速开始的第一步就是安装mongoDB了,一般很多人因为电脑本身环境问题,遇到一些奇奇怪怪的坑。所以我主要说明三种安装方式,以及我最推荐的方式。前人之述足矣,我就不在造轮子了,直接挂链接。

win10系统安装MongoDB

这篇博客详细的介绍了MongoDB的安装过程,并配置成了自启动服务,非常方便,亲测有效。

MongoDB的安装配置教程(很详细,你想要的都在这里)https://blog.csdn.net/weixin_43405300/article/details/120017878

Linux安装MongoDB

这篇博客详细的介绍了MongoDB的Linux安装过程,并配置成了自启动服务,非常方便,亲测有效。

需要注意的是:

  • 如果使用的虚拟机,一定要记得放开端口;如果是云服务器,一定要配置防火墙安全组端口。
  • 测试远程连接拿navicat一样的用法。
  • 配置完成Linux的环境后一定要source /etc/profile刷新环境

Linux CentOS7 环境下安装 MongoDBhttps://blog.csdn.net/chenlixiao007/article/details/110206062

Docker容器安装MongoDB(强烈推荐)

为什么推荐使用Docker容器安装,因为通过 Docker,你可以用单一命令轻松地下载、安装和运行 MongoDB,无需进行复杂的安装和配置。

需要注意:

  • 运行容器需要挂载目录和端口映射,下面这篇文章docker run 的时候指定了,所以也可以无脑跟。
  • 还是一样,需要注意服务器的防火墙端口一定要放开,放开之后要记得刷新。
    • sudo firewall-cmd --permanent --add-port=27017/tcp (设置端口)
    • sudo firewall-cmd --reload(刷新防火墙)
    • sudo firewall-cmd --list-all(查看安全组)

docker安装mongoDB及使用https://blog.csdn.net/packge/article/details/126539320

如果还没有安装docker的话,传送门如下:

Docker安装https://blog.csdn.net/qq_47959003/article/details/123957011

三、连接测试

不论是哪一种安装完成之后,用客户端软件登录的方式都是一样的。

  • 如果你没有设置密码,验证部分就直接None就好:
  • 如果设置了账号密码

这里首先需要说明一个误区,密码和传统数据如mysql等有些区别:

mongodb的用户名和密码是基于特定数据库的,而不是基于整个系统的。上面这个验证数据库也就是你指定存储用户名和密码的数据库。

刚开始了解MongoDB权限管理这方面确实有些摸不着头脑,因此我在MongoDB系统学习专栏中详细写了一些关于这方面的心得。

相关推荐
一只淡水鱼6629 分钟前
【mybatis】基本操作:详解Spring通过注解和XML的方式来操作mybatis
java·数据库·spring·mybatis
张声录131 分钟前
【ETCD】【实操篇(十六)】基于角色的访问控制:ETCD 安全管理指南
数据库·安全·etcd
warrah36 分钟前
redis——岁月云实战
数据库·redis·缓存
秀儿y37 分钟前
Redis-十大数据类型
数据库·redis·缓存·oracle
凡人的AI工具箱1 小时前
每天40分玩转Django:Django类视图
数据库·人工智能·后端·python·django·sqlite
路在脚下@1 小时前
MySQL的索引失效的原因有那些
数据库·mysql
凡人的AI工具箱1 小时前
每天40分玩转Django:实操图片分享社区
数据库·人工智能·后端·python·django
CT随1 小时前
MongoDB
数据库·mongodb
Fool丶玄浅2 小时前
【数据库系统概论】—— 关系数据库
数据库·数据库系统
DashVector2 小时前
如何通过HTTP API检索Doc
数据库·人工智能·http·阿里云·数据库开发·向量检索