MongoDB(4)- Collection 集合相关

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介: MongoDB(4)- Collection 集合相关

Collection


  • MongoDB 将文档存储在集合中
  • 集合存储在 Database 中
  • 集合类似于关系数据库(Mysql)中的表
  • 如果集合不存在,则 MongoDB 会在第一次存储该集合数据时创建该集合


image.png

MongoDB 集合的命名规则

集合名称要求符合 UTF-8 标准的字符串

序号 注意事项
1 集合名不能是空串,如""
2 不能含有空字符 null
3 不能以 system. 开头,这是系统集合保留的前缀
4 不能包含 $
5 命名空间最大为 255 bytes

对于分别部署在 Windows、Linux、UNIX 系统上的 MongoDB,集合的命名方式与数据库命名方式一致

 

显示所有集合


show collections

 

创建集合


MongoDB 集合的创建有显式和隐式两种方法

 

显示创建

使用 db.createCollection(name, options) 方法来实现

  • name:创建的集合名称
  • options:可选项,指定内存大小和索引等

db.createCollection("mySet", {capped:true,size:6142800, max :10000 })

 

常用 options

参数 类型 描述
capped Boolean (可选)如果为 true,则启用封闭的集合。上限集合是固定大小的集合,它在达到其最大时自动覆盖其最旧的条目。如果指定 true,则还需要指定 size 参数
size 数字 (可选)指定上限集合的最大大小(以字节为单位)。如果 capped 为 true,那么还需要指定次字段的值
max 数字 (可选)指定上限集合中允许的最大文档数

注意:在插入文档时,MongoDB 首先检查上限集合 capped 字段,然后检查 max 字段

 

隐式创建


  • 上面的 createCollection 方法,如果不需要指定 options 的时候,就没必要用显示创建
  • 因为 MongoDB 会在集合首次存储数据时自动创建新的集合

db.myDB.insert( {"name": "tom"} )

 

文档验证


  • 默认情况下,集合不要求存储的所有文档具有相同的数据结构
  • 即单个集合中的不同文档不需要具有相同的字段集
  • 并且一个字段的数据类型可以在集合内的文档中不同
  • 总结: Bson 数据结构、字段都不需要必须一致
  • 从 MongoDB 3.2 开始,可以在 update 和 insert 操作期间为集合强制执行文档验证规则(后面再展开讲)

 

修改文档数据结构


如果要改集合中文档的结构,可以添加新字段、删除现有字段、修改字段类型(后面再展开讲)

 

UUID


  • 集合会被分配一个不可变的 UUID
  • 集合 UUID 在副本集的所有成员和分片集群中的分片保持不变

 

查看集合的 uuid

>  db.getCollectionInfos()
[
    {
        "name" : "myNewCollection1",
        "type" : "collection",
        "options" : {
        },
        "info" : {
            "readOnly" : false,
            "uuid" : UUID("3929147e-5030-4353-938c-3405487d330f")
        },
        "idIndex" : {
            "v" : 2,
            "key" : {
                "_id" : 1
            },
            "name" : "_id_"
        }
    }
]


扩展


关于 Collection 还有蛮多方法的,后面用到再展开讲解哦

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
6月前
|
NoSQL MongoDB 数据库
04 MongoDB - 集合操作
04 MongoDB - 集合操作
23 0
|
9月前
|
NoSQL MongoDB 数据库
MongoDB常用的操作(服务器、数据库、集合)
MongoDB常用的操作(服务器、数据库、集合)
1974 0
|
10月前
|
NoSQL MongoDB Cloud Native
【mongo 系列】mongodb 学习十一,MongoDB 分片集群之分片集合
MongoDB 中 分片集群有专门推荐的模式,例如 分片集合
102 0
|
10月前
|
NoSQL MongoDB 数据库
MongoDB 删除集合
MongoDB 删除集合
79 0
|
10月前
|
NoSQL MongoDB 数据库
MongoDB 创建集合
MongoDB 创建集合
372 0
|
12月前
|
NoSQL MongoDB 数据库
开心档-软件开发入门之MongoDB 删除集合
【摘要】 本章节我们为大家介绍如何使用 MongoDB 来删除集合。
|
12月前
|
NoSQL MongoDB 数据库
软件开发入门教程网之MongoDB 创建集合
【摘要】 本章节我们为大家介绍如何使用 MongoDB 来创建集合。
|
12月前
|
缓存 NoSQL MongoDB
开心档-软件开发入门之MongoDB 固定集合(Capped Collections)
【摘要】 本章将会讲解MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环形队列,当集合空间用完后,再插入的元素就会覆盖最初始的头部的元素!
|
12月前
|
NoSQL MongoDB 数据库
开心档 - 软件开发入门之 MongoDB 创建集合
本章节我们为大家介绍如何使用 MongoDB 来创建集合。MongoDB 中使用 createCollection() 方法来创建集合。语法格式:
开心档 - 软件开发入门之 MongoDB 创建集合
|
12月前
|
NoSQL MongoDB 数据库
一日一技:如何找到 MongoDB 占用空间最大的集合?
一日一技:如何找到 MongoDB 占用空间最大的集合?
254 0