mongdb 基本概念

简介: mangodb可以有多个instance,一个instance可以有多个database, database又可以有多个collection,每个collection也可以有多个document 1、文档(Document) mongoDB的基本单位,相当于关系数据库中的行。它是一组有序的key/value键值对, 使用json格式,如:{"

mangodb可以有多个instance,一个instance可以有多个database,

database又可以有多个collection,每个collection也可以有多个document


1、文档(Document)

mongoDB的基本单位,相当于关系数据库中的行。它是一组有序的key/value键值对,

使用json格式,如:{"foo" : 3, "greeting" "Hello, world!"}。

(1)key是个UTF-8字符串,以下几点是需要注意的地方:

  • 不能包含\0字符(null字符),它用于标识key的结束
  • .和$字符在mangodb中有特殊含义,如$被用于修饰符($inc表示更新修饰符),应该考虑保留,以免被驱动解析
  • 以_开始的key也应该保留,比如_id是mangodb中的关键字
         在mangodb中key是不能重复的

(2)value 是弱类型,甚至可以嵌入的一个document

(3)key/value键值对在mangodb中是有序的

(4)mangodb是类型和大小写敏感的,如{"foo" : 3}和{"foo" : "3"}是两个不同的document,{"foo" : 3}和{"Foo" : 3}类似


2、集合(Collection)

相当于关系数据库的表,不过没有数据结构的定义。它有多个document组成。

因为是无结构定义的,所以你可以把任何document存入一个collection里。每个

collection用一个名字标识,需要注意以下几点:

  • 名字不允许是空字符串""
  • 名字不能包含\0字符,因为它表示名字的结束
  • 不能创建以system.开头的


3、数据库(Database)

一个mongoDB的实例可以运行多个database,database之间是完全独立的,每个database有自己的权限,每个database存储于磁盘的不同文件。

同collections的name一样,databases的name可以是任意的UTF-8字符串。但是有以下限制:

  • 空字符串””是非法的
  • 不允许出现’’,.,$,/,\,\0字符
  • 建议名称都是小写
  • 不能超过64个字节

有几个保留的名字不能用在databases的name中:

  • admin:它是root级别的数据库,如果一个用户创建了admin数据库,该用户将自动集成所有数据库的权限,它可以执行一些服务器级别的命令,如列出所有数据库、关闭服务等。
  • local:该数据库将永远不能被复制,只能在单台服务器本地使用。
  • config:存储分布式部署时shard的配置信息

4、数据类型

  • null
             表示一个空值或者不存在的字段,如{"x":null}
  • boolean
             使用true或false表示值,如{"x" : true}
  • 32位整数
             shell中无法表示,javascript只支持64位浮点小数,所以会被转化为64位浮点小数。
  • 64位整数(同上)
  • 64位浮点小数
             在shell中所有数字都使用该类型,如{"x" : 3.14}、{"x" : 3}
  • string
             任何UTF-8的字符
  • symbol
             shell不支持此类型,来自数据库中的symbol类型数据会转化为字符串
  • object id
             0 1 2 3     |4 5 6     |7 8   |9 10 11

             Timestamp|Machine | PID  |Increment

             如{"x" : ObjectId()}

  • date
             表示距离新纪元的毫秒数,如{"x" : new Date()}
  • 正则表达式
如何javascript语法的正则表达式
如{"x" : /foobar/i}
  • code

javascript的代码

如{"x" : function() { /* ... */ }}

  • 二进制数据
  • maximum value
    bson有这样一个专门的类型来表示可能的最大值,shell不支持此类型。
  • minimum value
  • undefined
  • array
  • embeded document

目录
相关文章
|
5月前
|
存储 NoSQL 关系型数据库
mongodb 基本概念
mongodb 基本概念
|
6天前
|
存储 NoSQL 关系型数据库
MongoDB简介以及核心概念
MongoDB简介以及核心概念
17 1
|
3月前
|
存储 NoSQL 关系型数据库
|
3月前
|
存储 NoSQL 关系型数据库
1-MongoDB相关概念
1-MongoDB相关概念
|
4月前
|
SQL 存储 关系型数据库
MYSQL数据库-基础概念
MYSQL数据库-基础概念
|
8月前
|
SQL 关系型数据库 MySQL
Mysql数据库基础概念
本文介绍了MySQL数据库的基础概念以及SQL语言的简介。数据库管理系统(DBMS)是数据存储和管理的关键工具,MySQL作为开源关系型数据库管理系统在性能和可靠性方面表现出色。数据库是有组织的数据集合,其中包含多个数据表,每个表由数据行和列组成,类似于电子表格。SQL语言是一种用于管理和查询关系型数据库的标准化语言,包括数据查询、插入、更新、删除操作,以及定义数据库结构和控制数据访问权限。掌握这些基本概念和操作将为用户提供在MySQL数据库中进行数据操作和管理的基础,为应用开发和数据处理提供支持。
66 0
|
9月前
|
机器学习/深度学习 分布式计算 NoSQL
【mongo 系列】mongodb 学习四,聚合知识点梳理
数据聚合(Data Aggregation)是指合并来自不同数据源的数据。. 聚类也称聚类分析,亦称为群集分析,是对于统计数据分析的一门技术, 在许多领域受到广泛应用,包括机器学习,数据挖掘,模式识别,图像分析以及生物信息。
227 4
|
10月前
|
存储 监控 NoSQL
MongoDB的基本概念和主要特点
MongoDB的基本概念和主要特点
148 0
MongoDB的基本概念和主要特点
|
存储 分布式计算 监控
MongoDB :第二章:系统归纳
MongoDB :第二章:系统归纳
131 0
MongoDB :第二章:系统归纳
|
存储 JSON NoSQL
玩转MongoDB—基本概念及初步使用
玩转MongoDB—基本概念及初步使用