MongoDB超级简明入门教程

摘要:
1.概念篇 MongoDB和MySQL分别作为非关系型数据库和关系型数据库的代表,通过它们之间的对比可以很快的建立起对MongoDB的认知。 MongoDB MySQL 数据库(Database) 数据库(Database) 集合(Collection) 表(Table) 文档(Document) 记录(record)

1.概念篇

MongoDB和MySQL分别作为非关系型数据库和关系型数据库的代表,通过它们之间的对比可以很快的建立起对MongoDB的认知。

MongoDBMySQL
数据库(Database)数据库(Database)
集合(Collection)表(Table)
文档(Document)记录(record)

对于关系型数据库,一般来说,我们可以简单的理解为:一个数据库管理应用,可以创建多个数据库(databases),每个数据库可以管理很多个表(tables),表中存储的就是可以CURD的记录(records),这种管理层级同样可以映射到MongoDB上。

与MySQL不同的是,MongoDB的数据具有灵活的模式 。集合本身没有对文档结构的规则性校验,而表的设计从一开始就约束死了记录该包含的字段名。

需要注意的是,MongoDB作为非关系型数据库,不是说其我们使用时不能设计成关系型的结构,我们同样可以人为地约束(document)文档结构包含的数据的类型,(与MySQl不同的是,MongoDB的文档支持数组和对象、子文档等复杂的数据结构)同样文档之间也可以设计成类似ER图的关系模型。
下面是官网提供的一个书籍分类树形结构数据建模的例子
MongoDB超级简明入门教程第1张

传统的关系型数据库的设计思想是把每个节点当做一个记录,每个节点保存其父节点的_id.

_idparent
MongoDBDatabases
dbmDatabases
DatabasesProgramming
LanguagesProgramming
ProgrammingBooks
Booksnull

这种关系也可以使用MongoDB存储

db.categories.insert( { _id: "MongoDB", parent: "Databases" } )
db.categories.insert( { _id: "dbm", parent: "Databases" } )
db.categories.insert( { _id: "Databases", parent: "Programming" } )
db.categories.insert( { _id: "Languages", parent: "Programming" } )
db.categories.insert( { _id: "Programming", parent: "Books" } )
db.categories.insert( { _id: "Books", parent: null } )

其他几种树形结构的建模方法请参考
Model Tree Structures
Modeling a Tree in a Document Database

2.快速操作篇

  • 下载安装客户端 https://docs.mongodb.com/manual/administration/install-community/
  • 开启MongoDB服务
    (1)创建数据库存储目录

    mkdir -p ~/yourdir/db
    

    确保当前用户拥有该目录的读写权限
    (2)开启服务

    mongod --dbpath <path to data directory>
    

    再此之前确保mongod命令路径已经加入到了系统环境变量

  • 使用mongo shell 操作数据库
    (1)连接到数据库,开启命令模式

    mongo --host 127.0.0.1:27017
    

    如果使用默认参数,后面的参数可以省略
    (2)显示目前操作的数据库

    db
    

    (3)切换数据库

    use <database>
    

    当第一次存储数据到数据库时,MongoDB会自动创建数据库及集合

    use myNewDatabase
    db.myCollection.insertOne( { x: 1 } );
    

    上面的insertOne语句会自动创建myNewDatabase数据库,与myCollection集合。

3.MongoDB 增删改查 操作

db.collection.insertOne()
db.collection.insertMany() 
db.collection.deleteOne()
db.collection.deleteMany()
db.collection.updateOne()
db.collection.updateMany()
db.collection.replaceOne()
db.collection.find()

免责声明:文章转载自《MongoDB超级简明入门教程》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇postman导出Collection文件macOS下通过docker在局域网成功访问mysql5.6数据库下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

ORA-01089 数据库无法正常关闭

今天在做SOA几个数据库的重启操作,其中一个数据库在关闭过程中一直处于HANG住状态,十几分钟没有任何进展,具体操作过程如下: 一:当时的情景 SQL> shutdown immediate      --无任何返回结果 二:问题定位过程 1.查询相关进程只有ORACLE的关键进程存在    ps -ef |grep ora_    soadb  4...

android 网络编程--socket tcp/ip udp http之间的关系

网络七层由下往上分别为物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,一般编程人员接触最多的就是应用层和运输层,再往下的就是所谓的媒体层了,不是我们研究的对象。 下面是应用层、运输层,网络层、链路层通信协议概图。我们经常接触到的一般是: http协议:应用层协议,并且http协议是基于tcp连接的,主要解决的是如何包装协议的 tcp协议:运输层...

MSSQl分布式查询

MSSQlServer所谓的分布式查询(Distributed Query)是能够访问存放在同一部计算机或不同计算机上的SQL Server或不同种类的数据源, 从概念上来说分布式查询与普通查询区别 它需要连接多个MSSQL服务器也就是具有多了数据源.实现在服务器跨域或跨服务器访问. 而这些查询是否被使用完全看使用的需要. 本篇将演示利用SQlExpres...

网络知识收集

最近学习Ravello虚拟化,遇到一些和网络相关的知识,收集后整理如下: L2其实是指七层网络协议中的第二层数据链路层,它的传输是以mac地址为基础L3指网络层:是以ip地址为基础网络层属于OSI中的较高层次了,从它的名字可以看出,它解决的是网络与网络之间,即网际的通信问题,而不是同一网段内部的事。网络层的主要功能即是提供路由,即选择到达目标主机的最佳...

Mysql日期分组无数据查询填充0

前言 这篇文章标题不好取。。。(主要是生成连续的日期),本文关键点有:Mysql 获取指定时间段内的所有日期列表, Mysql 按照日期分组查询没有数据的日期也一并查询出来。 本文原文链接地址:http://nullpointer.pw/Mysql%E6%97%A5%E6%9C%9F%E5%88%86%E7%BB%84%E6%97%A0%E6%95%B0%...

数据库连接,事务以及Java线程的关系

0. 前言 Spring作为Java框架王者,当前已经是基础容器框架的实际标准。Spring 除了提供了IoC、AOP特性外,还有一个极其核心和重要的特性:数据库事务。事务管理涉及到的技术点比较多,想完全理解需要花费一定的时间,本系列《Spring设计思想-事务篇》将通过如下几个方面来阐述Spring的数据库事务: 数据库连接java.sql.Conne...