MongoDB 学习笔记(五):固定集合、GridFS文件系统与服务器端脚本
一、count、distinct与group
1、count函数:查询文档数,如下图:
2、distinct:去重,用法:db.runCommand({distinct:"集合名", key:"查询的键"}),如下图:
3、group:分组,语法如下:首先会按照key指定的键进行分组,每组的每一个文档都要执行$reduce指定的方法,该方法接收2个参数,一个是组内本条文档,一个是累加器数据。
- db.runCommand({group:{
- ns: 集合名,
- key: 分组的键,
- initial: 初始化累加器,
- $reduce: 组分解器,
- condition: 条件,
- finalize: 组完成器
- }})
比如,查询每个班中年龄大于18岁,得分最高的学生信息,如下图:
而使用finalize组完成器,可以对最终要返回的结果集加以额外的修饰,如下图:
4、用函数格式化分组的键
如下图,最后一条文档不包含class这个键,而有clAss这个键。
在分组时却要把该条文档的clAss这个键当作class键进分组,那么可以使用函数格式化分组的键,如下图:
二、数据库命令操作
1、命令执行器runCommand
之前有说过这个命令,也有使用过。比如删除集合可以使用db.集合名.drop(),而使用该命令执行drop命令也可以删除一个集合:db.runCommand({drop: "集合名"})。
2、查询MongoDB提供的可以供runCommand执行的命令
- shell中查看:db.listCommands()。
- 登录数据库服务器web端:http://localhost:28017/_commands。前提是在启动数据库服务时加入了rest参数,如下图:
3、常用命令
- 查询服务器版本与主机操作系统等信息
- 查询某个集合的详细信息:
- 查询操作某个集合的最后一次错误信息:
三、固定集合
1、创建一个空的普通集合:db.createCollection("集合名")
2、创建一个新的固定集合,要求大小是100字节(?),且可以存储5个文档
3、把一个普通集合转换成固定集合
4、固定集合的特性
- 如果在固定集合文档数达到指定的最大文档数量时继续插入文档,它会删除集合中最后一个文档,然后在该位置插入新的文档。
- 固定集合的顺序是确定的,所以查询速度是非常块的。
5、反向排序(对于普通集合和固定集合都适用)
当使用find函数查询集合时,如果不指定任何排序规则,默认就是按照插入的顺序进行排序的,等同于使用sort函数,并指定$natural键为1(大于-1的数字即可),如下图:
指定$natural键小于0,就可以按照插入顺序的反向顺序进行排序,如下图:
6、尾部游标
这是个特殊的只能用在固定集合上的游标,它在没有结果的时候也不会自动销毁,而是一直等到结果的到来。shell中不支持,一些高级的驱动才支持。
四、GridFS文件系统
1、GridFS是MongoDB自带的文件系统。
2、上传一个文件到GridFS文件系统中:mongofiles -d 数据库名字 -l "要上传的文件的完整路径名" put "上传后的文件名"。如下图:
然后在mdb数据库中就会多出2个集合,它们存储了GridFS文件系统的所有文件信息,查询这两个集合就能看到上传的那个文件的一些信息,如下图:
3、从GridFS文件系统中下载一个文件到本地:mongofiles -d 数据库名字 -l "将文件保存在本地的完整路径名" get "GridFS文件系统中的文件名",如下图:如果不写-l以及后面的路径参数,则保存到当前位置。
4、查看GridFS文件系统中所有文件:mongofiles -d 数据库名字 list,如下图:
5、删除GridFS文件系统中的某个文件:mongofiles -d 数据库名字 delete "文件名",如下图:
五、服务器端脚本
1、服务器端运行eval,如下图:
2、JavaScript的存储
在数据库服务器端可以保存js变量或者函数到system.js这个特殊集合中,以供全局调用,如下图:当执行eval时就会到system.js集合中查看有没有_id键为age的全局变量,如果找不到在看看age是不是一个已经定义了的局部变量,否则报错。
如果是定义成函数就类似于关系型数据库中的存储过程,如下图:
MongoDB 学习笔记(五):固定集合、GridFS文件系统与服务器端脚本的更多相关文章
- Mongodb学习笔记五(C#操作mongodb)
mongodb c# driver(驱动)介绍 目前基于C#的mongodb驱动有两种,分别是官方驱动(下载地址)和samus驱动(下载地址). 本次我们只演示官方驱动的使用方法. 官方驱动文档查看 ...
- MongoDB学习笔记(五) MongoDB文件存取操作
由于MongoDB的文档结构为BJSON格式(BJSON全称:Binary JSON),而BJSON格式本身就支持保存二进制格式的数据,因此可以把文件的二进制格式的数据直接保存到MongoDB的文档结 ...
- MongoDB学习笔记五—查询上
数据准备 { , "goods_name" : "KD876", "createTime" : ISODate("2016-12- ...
- MongoDB学习笔记五:聚合
『count』count是最简单的聚合工具,返回集合中的文档数量:> db.foo.count()0> db.foo.insert({"x" : 1})> db. ...
- 【Linux_Shell 脚本编程学习笔记五、Oracle JDK1.8 安装shell 脚本】
脚本使用说明: 首先在脚本的同级目录下有个 jdk的安装包 脚本和安装包必须在同级目录下才能够安装(脚本没有优化,还可以使用 wget 从网上下载指定版本的 jdk 安装包) #!/bin/sh ...
- MongoDB学习笔记(转)
MongoDB学习笔记(一) MongoDB介绍及安装MongoDB学习笔记(二) 通过samus驱动实现基本数据操作MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB ...
- MongoDB学习笔记(二)--Capped集合 && GridFS存储文件
Capped集合 Capped集合的大小是固定的,如果空间都被用完了,新添加的对象 ...
- MongoDB学习笔记(五)--复制集 && sharding分片
主从复制 主从节点开启 主节 ...
- MongoDB学习笔记:快速入门
MongoDB学习笔记:快速入门 一.MongoDB 简介 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.在高负载的情况下,添加更多的节点,可以保证服务器性能.M ...
随机推荐
- 学习Linux服务的方法
1.服务的概述:名字.功能.特点.原理.端口号 2.安装 3.配置文件的位置 4.服务器启动.关闭的脚本,查看端口 5.此服务的使用方法 6.修改配置文件,案例部署 7.排错调优
- 24.基于groovy脚本进行partial update
主要知识点 在es中其实是有内置的脚本支持的,可以基于groovy脚本实现各种各样的复杂操作 基于groovy脚本,如何执行partial update es scripting module,我们会 ...
- Spring Boot实例Hello World Demo
Spring Boot要求Maven的版本达到3.2或以上. 实例: POM: <project xmlns="http://maven.apache.org/POM/4.0.0&qu ...
- 今天玩了tensorflow playground,太好玩了
先上地址: http://playground.tensorflow.org 我试了一个最复杂的,螺旋形的.开始怎么训练都不行.后来我多加了几个神经元,居然能训练成功了.真是太牛逼了!
- 多个线程作用于同一个runnable对象
多个线程作用于同一个runnable对象 学习了:https://www.cnblogs.com/ligang305/archive/2012/08/10/2632126.html http://as ...
- android小技巧:在activity中实现与绑定的fragment的回调
看到标题你可能会想是一个多么高大上的技巧呢?事实上非常一般就是自己定义回调函数. 首先我们知道activity之间的数据传递有几种方式: 一是startActivityForResut()启动一个ac ...
- Unity3D与JSP TomCatserver传递数据和文件( 二 ) Unity3D向java传输表单
扫码关注微信公众号,获取最新资源 经历了一天的工作.我又来更新啦...白天手欠,把上一个给删了.明天重写吧.. 废话不多说.我们先去Unity里创建一个能够输入username和password的登录 ...
- 一张游览PHP内核迷宫的藏宝图
PHP内核就像一个迷宫,假设没有一个纵览全局的图,仅仅是面对当中的一个点,就会像进了迷宫一样,走着走着就走到了死胡同.在这个迷宫里转悠了非常久之后,近期得到了一张PHP藏宝图.然后看着这张图去游览PH ...
- C语言 - 头文件使用案例
源代码分门别类管理,通过头文件. 放置一些函数声明,变量声明,常量定义,宏定义. hotel.h #ifndef HOTEL_H_INCLUDED #define HOTEL_H_INCLUDED # ...
- 现代英特尔® 架构上的 TensorFlow* 优化——正如去年参加Intel AI会议一样,Intel自己提供了对接自己AI CPU优化版本的Tensorflow,下载链接见后,同时可以基于谷歌官方的tf版本直接编译生成安装包
现代英特尔® 架构上的 TensorFlow* 优化 转自:https://software.intel.com/zh-cn/articles/tensorflow-optimizations-on- ...