MongoDB学习笔记——集合管理
创建集合
使用db.createCollection(name, options) 方法创建集合 name 所创建的集合名称必选! options 可选。指定有关内存大小及索引的选项
db.createCollection("mycollection")
--或
db.mycollection.insert( {
user_id: "abc123",
age: 55,
status: "A"
} )
使用db.COLLECTION_NAME.drop()方法删除集合
db.mycollection.drop()
使用db.COLLECTION_NAME.update() 方法可以修改集合结构
--添加字段
db.mycollection.update(
{ },
{ $set: { join_date: new Date() } },
{ multi: true }
)
--删除字段
db.mycollection.update(
{ },
{ $unset: { join_date: "" } },
{ multi: true }
)
使用show collections检查当前数据库集合列表
show collections
下表列出了options参数所有可用选项
|
字段 |
类型 |
描述 |
|
capped |
布尔 |
(可选)如果为 true,则创建固定集合。固定集合是指有着固定大小的集合,当达到最大值时,它会自动覆盖最早的文档。 |
|
autoIndexID |
布尔 |
(可选)如为 true,自动在 _id 字段创建索引。默认为 false。 |
|
size |
数值 |
(可选)为固定集合指定一个最大值(以字节计)。 |
|
max |
数值 |
(可选)指定固定集合中包含文档的最大数量。 |
在插入文档时,MongoDB 首先检查固定集合的 size 字段,然后检查 max 字段。
固定集合
固定集合是固定大小的集合支持基于文档插入顺序的高吞吐率的插入、检索、删除操作。限制收集工作在某种程度上类似于循环缓冲区:一旦一个文档填满分配给它的空间,他将通过在限制集中重写老文档来给新文档让出空间。
固定集合能够保留插入顺序。因此,查询并不需要索引来保证以插入顺序来返回文档。减少了索引的消耗,
固定集合可以支持更高的插入吞吐。
为了为新文档腾出空间,在不需要脚本或显式删除操作的前提下,固定集合自动删除集合中最旧的文档。
固定集合有一个 _id 字段并且默认在 _id 字段上创建索引。
注意事项:
如果一个更新或替换操作改变了文档大小,操作将会失败
不能从固定集合中进行删除文档,可以使用drop() 方法来删除集合然后重新创建限制集。
固定集合不支持分片
db.createCollection( "mycache", { capped: true, size: 100000 } )
检查是否为固定集合
db.mycollection.isCapped()
使用命令convertToCapped 转换一个非限制集成为一个限制集
db.runCommand({"convertToCapped": "mycollection", size: 100000})
关系型数据库与MongoDB数据库在一些术语上的对比
|
关系型数据库(mysql) |
MongoDB |
备注 |
|
CREATE TABLE users ( id MEDIUMINT NOT NULL AUTO_INCREMENT, user_id Varchar(30), age int, status char(1), PRIMARY KEY (id) ) |
db.users.insert( { user_id: "abc123", age: 55, status: "A" } ) 或 db.createCollection("users") 如果文档中不指定``_id``列,那么会自动添加``_id``列并默认为主键 |
创建集合 |
|
ALTER TABLE users ADD join_date DATETIME |
db.users.update( { }, { $set: { join_date: new Date() } }, { multi: true } ) |
追加字段 |
|
ALTER TABLE users DROP COLUMN join_date |
db.users.update( { }, { $unset: { join_date: "" } }, { multi: true } ) |
删除字段 |
|
DROP TABLE users |
db.users.drop() |
删除集合 |
|
show tables |
show collections |
查询当前数据库中所有集合 |
MongoDB学习笔记——集合管理的更多相关文章
- MongoDB学习笔记—权限管理
1.MongoDB权限介绍 a 上篇文章中,我们在Linux下配置了MongoDB环境并且将其设置为服务随机器启动而启动,那么接下来这篇文章我们就来简单说一下MongoDB下对登录用户权限的管理. b ...
- MongoDB学习笔记——索引管理
索引 索引能够提升查询的效率.没有索引,MongoDB必须扫描集合中的所有文档,才能找到匹配查询语句的文档. 索引是一种特殊的数据结构,将一小块数据集保存为容易遍历的形式.索引能够存储某种特殊字段或字 ...
- MongoDB学习笔记(二)--Capped集合 && GridFS存储文件
Capped集合 Capped集合的大小是固定的,如果空间都被用完了,新添加的对象 ...
- mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...
- MongoDB学习笔记:快速入门
MongoDB学习笔记:快速入门 一.MongoDB 简介 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.在高负载的情况下,添加更多的节点,可以保证服务器性能.M ...
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
- PHP操作MongoDB学习笔记
<?php/*** PHP操作MongoDB学习笔记*///*************************//** 连接MongoDB数据库 **////*************** ...
- MongoDB 学习笔记(原创)
MongoDB 学习笔记 mongodb 数据库 nosql 一.数据库的基本概念及操作 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table ...
- MongoDB学习笔记(六)--复制集+sharding分片 && 总结
复制集+sharding分片 背景 主机 IP 服务及端口 Server A ...
随机推荐
- 6/19 sprint3 看板和燃尽图的更新
- Qt Style Sheet实践(三):QCheckBox和QRadioButton
导读 单选按钮(QRadioButton)和复选框(QCheckBox)是界面设计中的重要元素.单选按钮只允许用户在一组选项中选择一个,且当其中一个被选中的时候,按钮组中的其他单选按钮自动取消.复选框 ...
- SQL Server 多条记录的某个字段拼接
USE [FM_Dev] GO /****** 对象: UserDefinedFunction [dbo].[GetClassNameByStudentCode] 脚本日期: 05/23/2014 1 ...
- jQuery的事件one
如果你只想你设计的对象只能让用户执行一次的话,可以使用jQuery的事件one()来实现. 演示一个,创建视图, 看看效果:
- 【C#】委托
一.委托的基本的写法 internal class Program { private static void Main(string[] args) { ChainDelegate(); Conso ...
- poi 导出 excel
private void exportAssetExcel(HttpServletRequest request, HttpServletResponse response) throws IOExc ...
- EffectiveJava——用函数对象表示策略
有些语言支持函数指针.代理.lambda表达式,或者支持类似的机制,允许程序把“调用特殊函数的能力”储存起来并传递这种能力.这种机制通常用于允许函数的调用者通过传入第二个函数,来指定自己的行为.比较器 ...
- Java synchronized关键字用法(清晰易懂)
本篇随笔主要介绍 java 中 synchronized 关键字常用法,主要有以下四个方面: 1.实例方法同步 2.静态方法同步 3.实例方法中同步块 4.静态方法中同步块 我觉得在学习synchro ...
- php 7 windows redis 扩展
搜了一圈也没找到redis 对于 php 7 windows 扩展,最后还是在apache lounge论坛找到了php7全扩展包 本人把里面的扩展全进行了上传(下载见本文底部) 在这里主要讲讲 ph ...
- ASP.NET Web API 路由
路由系统是请求消息进入ASP.NET Web API消息处理管道的第一道屏障,其根本目的是利用注册的路由表(RouteTable)对请求的URI进行解析以确定目标HttpController和Acti ...