(二)MongoDB基本概念

mongodb

2018年03月07日 08时43分53秒


mognoDB是一个面向文档的数据库,而不是关系型数据库,是不是用关系型数据库主要是为了获得更好的扩展性,还会有其他的诸多的好处。基本的使用了解下面的一部分概念就可以了,不需要太较真。

初级学习,mongoDB的灵活性主要从下面的两个方面凸显:

  1. 与关系型数据库相比较不再具有行(row)的概念,使用文档模型(document)取代关系型数据库中的行,且每一个文档中都可以再次嵌入文档与数组。故面向文档可以使用一条记录表现复杂的层次关系。
  2. 不再具有预定的列,文档中表现值与索引的方式不再是列名与值,而是键(key)与值(value),且key-value没有固定的类型与大小,是在插入数据的时候指定的,这样每一个表(对应mongo中的集合)中的文档(也就是行)不用在具有相同的列了,添加删除字段变得更加的容易了。

数据结构模型

看着上面的模型图来说一下mongo的基本概念:

  • 文档(document):是mongoDB中的基本单元,非常类似于关系型数据库中的行

    {“url” : “www.baidu.com”}

    上面的就是一个最简单的文档,key是url,value是www.baidu,com

    作为key只能是字符串格式,且区分大小写,同一个文档中key不能重复;value是可以是多种格式,不过目前经常使用的无非是内嵌文档、数组、字符串、整型,在后面的操作练习中会对这几种类型提供例子。

  • 集合(collection):就是一个拥有动态模式的表,相当于关系型数据库中的表;动态模式是指集合中的每一个文档可以不必具有相同结构、相同类型的字段,每一个文档都具有的就是"_id"。

    {“age” : 18}

    {“url” : “www.baidu.com”}

    上面的两个文档是可以存储在同一个集合中的。

  • 数据库(database):mongoDB安装在一台机器上的mongo称之为一个实例,一个mongoDB实例可以拥有多个相互独立的数据库。

  • 每个文档都有一个特殊的键“_id”,这个键在一个集合中是唯一的

    我们将上面的{“url” : “www.baidu.com”}插入数据库来查看一下在数据库中存储的结构:

    查询语句(下一节分析查询语法):db.blog.find({“url” : “www.baidu.com”}).pretty();

    { “_id” : ObjectId(“5a231b3b8d1128d0c73b3496”), “url” : “www.baidu.com” }

    可以看出给本文档增加了一个_id,当然我们也可以自己指定_id,不过不是特别推荐。

总的来说mongoDB的基本特点可以总结为以下类型:

  1. 面向集合(collenction)

    每个集合在数据库中都有一个唯一的标志名,每个文档可以包含无限多个文档,类似于关系型数据库中的表。
  2. 模式自由

    value可以是任何形式的数据,在同一个文档中可以包含多个种类的数据类型
  3. 文档型

    存储的数据是KV(键值对)的形式,key是字符串,插入的时候不用指定key的类型,系统会自动将其转换为字符串类型;value可以为数据集合里面的任意类型包括数组和文档。

(二)MongoDB基本概念的更多相关文章

  1. 003.MongoDB主要概念

    一 对比关系 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行 ...

  2. CRL快速开发框架系列教程十二(MongoDB支持)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  3. SQLite入门与分析(二)---设计与概念(续)

    SQLite入门与分析(二)---设计与概念(续)   写在前面:本节讨论事务,事务是DBMS最核心的技术之一.在计算机科学史上,有三位科学家因在数据库领域的成就而获ACM图灵奖,而其中之一Jim G ...

  4. mongodb基本概念解析

    MongoDB 概念解析 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档.集合.数据库,下面我们挨个介绍. 下表将帮助您更容易理解Mongo中的一些概念: SQL术 ...

  5. 学习MQ(二)基本概念

    学习MQ(二)基本概念 这次简单罗列一下MQ的基本概念,还有我对它们的理解 1.queue manager 队列管理器,这是MQ系统中最上层的一个概念.每一个queue manager都有一个侦听器, ...

  6. JVM 内部原理(二)— 基本概念之字节码

    JVM 内部原理(二)- 基本概念之字节码 介绍 版本:Java SE 7 每位使用 Java 的程序员都知道 Java 字节码在 Java 运行时(JRE - Java Runtime Enviro ...

  7. MongoDB入门二:基本概念

    前言 工欲善其事必先利其器.在学习MongoDB之前,需要对MongoDB的一些基本概念有系统的了解. 所以,本篇文章主要介绍MongoDB的一些基本概念,这些概念的定义均来自<MongoDB权 ...

  8. 《mongoDB》概念-数据类型

    一:概念 - mongoDB 是一个面向文档的数据库,而不是关系型数据库. - 摘自<mongoDB 权威指南 第2版>第3页 二:数据类型 - null - 用于表示空值或者不存在的字段 ...

  9. MongoDB基本概念

    MongoDB是一种强大灵活可扩展的数据存储方式,它扩展了关系数据库的众多功能.MongoDB的功能非常丰富,但是却非常容易上手和便于使用,今天来了解一下MongoDB的主要概念. 文档 文档是的核心 ...

随机推荐

  1. python 项目实战之Django 邮件发送

    发送邮件¶ 虽然 Python 借助 smtplib 模块简化了发送邮件的流程,但是 Django 在其基础上提供了更简化的支持.这些封装意在加快邮件发送,方便在开发时测试发送邮件,在不支持 SMTP ...

  2. Apollo配置中心--安装使用-docker

    官网:https://github.com/ctripcorp/apollo Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推 ...

  3. MHA+keepalived集群环境搭建

    整个MHA+keepalived集群环境搭建 1.1. 环境简介1.1.1.vmvare虚拟机,系统版本CentOS6.5 x86_64位最小化安装,mysql的版本5.7.21,1.1.2.虚拟机器 ...

  4. centos7.2上安装CDH5.16.2及Spark2【原创】

    背景:我自己的电脑配置太低,想在centos操作系统上安装CDH5.1.2并配置集群,我去阿里云上买了3台按流量计费的阿里云服务器. 大家一定要注意,配置,购买的阿里云服务器不要太低了.建议:3台2核 ...

  5. Python 的 Pandas 对矩阵的行进行求和

    Python 的 Pandas 对矩阵的行进行求和: 若使用 df.apply(sum) 方法的话,只能对矩阵的列进行求和,要对矩阵的行求和,可以先将矩阵转置,然后应用 df.apply(sum) 即 ...

  6. python面试题300多题

    第一部分 Python基础篇(80题) 为什么学习Python? 通过什么途径学习的Python? Python和Java.PHP.C.C#.C++等其他语言的对比? 简述解释型和编译型编程语言? P ...

  7. thinkphp 6.0 swoole扩展websocket使用教程

    前言 ThinkPHP即将迎来最新版本6.0,针对目前越来越流行Swoole,thinkphp也推出了最新的扩展think-swoole 3.0. 介绍 即将推出的tp6.0,已经适配swoole.并 ...

  8. Win10 系统直接在目录下打开cmd

    每次用cmd命令,就要定位到当前文件夹,很麻烦 这里介绍一种直接定位到要操作的文件夹的方法: 操作步骤: (1)选择要cmd的文件夹,按住Shift键,鼠标右键快捷方式,先打开Powershell窗口 ...

  9. [转帖]【mount】Linux根目录空间不足

    [mount]Linux根目录空间不足 2019.04.15 21:30:47字数 1094阅读 107 一.问题背景 一台数据库服务器,突然监控告警,报根目录空间不足(no space left o ...

  10. [转帖]11G Undo使用率很高问题

    11G Undo使用率很高问题 http://blog.itpub.net/12679300/viewspace-1164916/ 原创 Oracle 作者:wzq609 时间:2014-05-20 ...