MongoDB学习之路(三)
数据库
一个MongoDB可以建立多个数据库。
MongoDB的默认数据库为"db",该数据库存储在data目录中。
MongoDB的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。
show dbs
可以显示所有的数据列表。
db
可以显示当前数据库对象或集合。
use
可以连接到一个指定的数据库
数据库名字的命名规范
- 不能是空字符串("")
- 不得含有''(空格)、 .、 $、 /、 和 \0(空字符)。
- 应全部小写
- 最多64个字节。
有一些数据库名字是保留的,可以直接访问这些有特殊作用的数据库。
- admin: 从权限的角度来看,这时"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令只能从这个数据库运行,比如列出所有的数据库或关闭服务器。
- local:这个数据库永远不会被复制,可以用来存储限于本地单台服务器的任意集合。
- config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
RDBMS与MongoDB之间的异同
RDBMS | MongoDB |
---|---|
数据库 | 数据库 |
表格 | 集合 |
行 | 文档 |
列 | 字段 |
表联合 | 嵌入文档 |
主键 | 主键(MongoDB提供了key为_id) |
文档
需要注意的是:
- 文档中键值对是有序的。
- 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
- MongoDB区分类型和大小写。
- MongoDB的文档中不能有重复的键。
- 文档的键是字符串。除了少数例外情况,键可以使用任意的UTF-8字符。
文档键命名规范:
- 键不能含有\0(空字符)。这个字符用来表示键的结尾。
- .和$有特别的意义,只有在特定环境下才能使用。
- 一下划线"_"开头的键是保留的(不是严格要求的)。
集合
集合就是MongoDB文档组,类似于RDBMS中的table。
集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都有一定的关联性。
一旦一个文档被插入时,集合就会被创建。
合法的集合名
- 集合名不能是空字符串""。
- 集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
- 集合名不能以"system."开头,这是为系统集合保留的前缀。
- 用户创建的集合名字不能含有保留字符。
元数据
数据库的信息是存储在集合中。它们使用了系统的命名空间:
dbname.system.*
在MongoDB数据库中名字空间.system.*是包含多种系统信息的特殊集合(Collection),如下:
集合命名空间 | 描述 |
---|---|
dbname.system.namespaces | 列出所有名字空间 |
dbname.system.indexes | 列出所有索引 |
dbname.system.profile | 包含数据库概要(profile)信息 |
dbname.system.users | 列出所有可访问数据库的用户 |
dbname.local.sources | 包含复制对端(slave)的服务器信息和状态 |
MongoDB数据类型
数据类型 | 描述 |
---|---|
String | 字符串。存储数据常用的数据类型。在MongoDB中,UTF-8编码的字符串才是合法的 |
Integer | 整型字符。用于存储数据。根据你所采用的服务器,可分为32位或64位。 |
Boolean | 布尔值。用于存储布尔值 |
Double | 双精度浮点值。用于存储浮点值。 |
Min/Max keys | 将一个值与BSON(二进制的JSON)元素的最低值和最高值相对比 |
Arrays | 用于将数组或列表或多个值存储为一个键 |
Timestamp | 时间戳。用于记录文档修改或添加的具体实践 |
Object | 用于内嵌文档。 |
Null | 用于创建空值 |
Symbol | 符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。 |
Date | 日期时间。用Unix时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建Date对象,传入年月日信息。 |
Object ID | 对象ID。用于创建文档的ID。 |
Binary Data | 二进制数据。用于存储二进制数据。 |
Code | 代码类型。用于在文档中存储JavaScript代码 |
Regular expression | 正则表达式类型。用于存储正则表达式 |
by 一枝猪
转载于:https://www.cnblogs.com/chunzhulovefeiyue/p/7243098.html
MongoDB学习之路(三)相关推荐
- Node.js+mongodb 学习笔记(三)swagger注释+用户管理
Node.js+mongodb 学习笔记(三)swagger注释+用户管理 Node.js+mongodb 学习笔记(三)swagger注释+用户管理 用户注册 用户登录 修改密码 swagger注释 ...
- Redis——学习之路三(初识redis config配置)
我们先看看config 默认情况下系统是怎么配置的.在命令行中输入 config get *(如图) 默认情况下有61配置信息,每一个命令占两行,第一行为配置名称信息,第二行为配置的具体信息. 我们就 ...
- typescript学习之路(三) —— ts定义类的方法(包含es5以及es6的定义类)
提起类,不得不说一下,强类型编程语言,如php,java,c++等都有类的概念.而js作为一门弱类型语言,是没有类这个概念的,虽然也能模拟类的实现,但总归不是类.so,ts也只是模拟类而已,使得更贴切 ...
- 函数式编程学习之路(三)
入门: 函数式编程之艰难,在于这玩意更接近数学,就是数学之"用",大牛们在云端,玩纯数学去了,弄出一堆公式及概念,码农们爬在地上,辛苦耕耘,要的是看得见摸得着的,函数式编程就是要打 ...
- MongoDB学习笔记(三)-----集群架构
MongoDB 有三种集群部署模式,分别为主从复制(Master-Slaver).副本集(Replica Set)和分片(Sharding)模式. Master-Slaver 是一种主从副本的模式,目 ...
- MongoDB学习笔记(三)使用Spring Data操作MongoDB
1.所需的包: 2.代码: (1)配置文件一:bootstrap.xml <?xml version="1.0" encoding="UTF-8"?> ...
- MongoDB学习笔记(三)
5 一些基本操作 #添加内嵌文档 db.users.update{{username:"master"},{$set:{hobby:{cities:["beijing&q ...
- ZYNQ学习之路(三):自定义IP实现PL处理PS写入BRAM的数据
目录 一.实验简介 二.vivado部分处理 三.SDK编程 四.实验测试 五.总结 一.实验简介 ZYNQ系列嵌入式FPGA可以使PS将数据写入PL部分BRAM,PL可以将数据读取后再重新写入BRA ...
- Cocos2d学习之路三(使用Zwoptex创建精灵表单和CCAnimate动画)
创建精灵表单: 创建动画先要把图片整合到一个图片上然后生成plist文件: 方法下载Zwoptex软件:http://www.zwopple.com/zwoptex/ 然后打开选择 create ne ...
最新文章
- 解决 MSChart控件 X轴坐标显示不全的问题
- VS2010下安装boost库
- Ubuntu16.04在线安装MongoDB详细教程
- hihocoder #1329 : 平衡树·Splay
- 问题 | 执行pip install --upgrade --ignore-installed tensorflow出现Cannot open\Scripts\pip-script.py
- 福音!微信个人公众号可以改名了!
- 【基础知识】Sticky Bit, SUID,SGID
- 【学习笔记】MOOC 数学文化赏析 笔记
- TensorFlow 第四步 多层神经网络 Mnist手写数字识别
- 《剑指 Offer I》刷题笔记 20 ~ 30 题
- 辞职腾讯去了小公司,从0到1搭建后端架构,工资就翻倍了
- 简书优秀IT专栏作者推荐
- CAPL函数 Test Node中注册事件(TestJoin xxx)函数
- dtft变换的性质_DTFT及其性质
- 传智黑马java基础学习——day32
- 操作系统课程设计 Pintos 1 ALarm Clock 问题
- 云计算和计算机应用的区别,普适计算与云计算的区别
- 目标追踪拍摄?目标遮挡拍摄?拥有19亿安装量的花瓣app,究竟有什么别出心裁的功能如此吸引用户?
- /bin/bash: warning: setlocale: LC_ALL: cannot change locale (en_US.UTF-8)
- 电赛校赛总结----一维板球系统【代码开源】