Mongodb学习笔记(二)Capped Collection固定集合
一、Capped Collection固定集合
简单介绍
capped collections是性能出色的有着固定大小的集合(定容集合),以LRU(Least Recently Used最近最少使用)规则和插入顺序进行 age-out(老化移出)处理,自动维护集合中对象的插入顺序,在创 建时要预先指定大小。如果空间用完,新添加的对象将会取代集合中最旧的对象。
功能特点
可以插入及更新,但更新不能超出 collection 的大小,否则更新失败。不允许删除,但是可 以调用 drop() 删除集合中的所有行,但是 drop 后需要显式地重建集合。在 32 位机上,一 个capped collection的最大值约为482.5M,64 位上只受系统文件大小的限制。
1、创建固定集合
createCollection("my_collection",{capped:true,size:10000})
创建一个名为“my_collection”的固定集合,大小为10000字节。还可以限定文档个数加上Max:100属性。
注意:指定文档上限,必须制定大小。文档限制是在容量没满进行淘汰,要是满了,就根据容量限制来淘汰。
2、转换集合
db.runCommand({convertTocapped:"text",size:10000});
把text普通集合转换为固定集合,大小为10000字节
3、自然排序---$natural(默认顺序是按照插入顺序返回的)
db.my_collection.find().sort({"$natural":1}) //1标示默认顺序,-1则相反
二、GridFS
简介:
GridFs是一种在MongoDB中存储大二进制文件的机制,使用GridFs的原因有以下几种:
储存巨大的文件,比如视频、高清图片等。
利用GridFs可以加化需求。
GridFs会直接利用已经建立的复制或分片机制,故障恢复和扩展都很容易。
GridFs可以避免用户上传的文件系统出现问题。
GridFs不产生磁盘碎片。
GridFs使用两个表来存储数据:
files 包含元数据对象
chunks 包含其他一些相关信息的二进制快
为了使多个GridFs命名为一个单一的数据库,文件和块都有一个前缀,默认情况下,前缀是fs,所以任何默认的GridFs存储将包括命名空间fs.files和fs.chunks.
各种第三方语言可以更改其前缀。
1、使用GridFs mongofiles
mongodiles是从命令行操作GridFs的一种工具
三个命令:
put(存储) ./mongofiles put 文件
get(取得) ./mongofiles get 文件
list(列表) ./mongofiles list
delete(删除)
Mongodb学习笔记(二)Capped Collection固定集合的更多相关文章
- MongoDB学习笔记二- Mongoose
		MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ... 
- MongoDB学习笔记(二) 通过samus驱动实现基本数据操作
		传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由(database).集合(collection).文档对象(documen ... 
- Mongodb 学习笔记(二) :索引
		Mongodb 是基于集合建立索引 (Index),索引的作用类似于传统关系型数据库,目的是为了提高查询速度 . 如果没有建立索引, Mongodb 在读取数据时必须扫描集合中的 所有文档记录. 这 ... 
- MongoDB学习笔记二—Shell操作
		数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ... 
- Mongodb学习笔记二(Mongodb基本命令)
		第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ... 
- MongoDB学习笔记二:创建、更新及删除文档
		插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个&q ... 
- MongoDB学习笔记(二)
		MongoDB的其他方法: 显示指定数目的数据: 1.在mongodb中查询指定数目的记录,可以使用: db.collectionname.find().limit(number); 2.在mongo ... 
- MongoDB学习笔记二:使用Docker安装MongoDB
		目录 Docker安装MongoDB Docker给MongoDB设置用户密码 NoSQL Manager for MongoDB连接 为admin赋权限 上一个笔记介绍了Windows下安装Mong ... 
- MongoDB 学习笔记之 删除数据,集合,数据库
		删除数据,集合,数据库: 删除一个文档: db.media.deleteOne({"name": "Sky"}) 删除多个文档: db.media.delete ... 
随机推荐
- shell-快速抽样
			有时我们需要对文件进行抽样,这时候只需要一个shell命令就可以抽取固定行数的样本:shuf shuf -n $m $file 参数有2: -n: 抽样行数 -r: 是否重复 
- 假期学习【六】Python网络爬虫2020.2.4
			今天通过Python网络爬虫视频复习了一下以前初学的网络爬虫,了解了网络爬虫的相关规范. 案例:京东的Robots协议 https://www.jd.com/robots.txt 说明可以爬虫的范围 ... 
- PHPstorm配置xdebug问题小记
			安装的是符合自己环境的xdebug,因为是按照xdebug官网的步骤安装的:安装什么版本检测地址:https://xdebug.org/wizard.php,安装操作复制phpinfo()内容之后点击 ... 
- phpstorm更换主题
			打开PhpStorm,File -- Settings -- Editor -- Color Scheme --General选择你喜欢的风格进行更改,选择完成后单击Apply 
- 原生js来写获取元素距离顶部距离,以及滚动条滚动指定距离和时间控制
			这是我在写vue项目里封装的一个公共js类 里面还有一些其他的方法,一并拿过来了 class Public { isDesktop(){ //判断是否为pc端 return (window.scree ... 
- 《Vue.js实战》--推荐指数⭐⭐⭐⭐
			献上pdf版本的百度网盘链接: https://pan.baidu.com/s/1YRwyR_ygW3tzBx1FbfjO1A 提取码: b255 先来看下目录: 看完这本书大概花了一个星期,走马观花 ... 
- python3练习100题——028
			原题链接:http://www.runoob.com/python/python-exercise-example28.html 题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁.问第4 ... 
- 0216 aop和打印数据库执行日志
			需求 maven依赖 <dependency> <groupId>p6spy</groupId> <artifactId>p6spy</artif ... 
- C++-hihoCode1545-小Hi和小Ho的对弈游戏[树上Nim]
			#include <set> #include <map> #include <cmath> #include <queue> #include < ... 
- 组合数的计算以及组合数对p取余后结果的计算
			前奏:统计 n! 中的所有质因子中pi的个数 普通方法:复杂度O(nlogn), 当n为10的18次方无法承受 // 复杂度O(nlogn), n为10的18次方无法承受 int cal(int n, ... 
