MongoDB创建视图(十四)

国庆放大假,随手翻了一下娃的英语词汇题,看到了idea、opinion、view和thought四个选项,忽然就想到了MongoDB的新特性Read-Only View,所以就顺便推广一下。

记得MongoDB World上宣布MongoDB下一个版本3.4会带来很多为之眼前一亮的新特性,其中第一个就是View,所以国庆长假期间,我们就先睹为快吧!

出世

View这个词对专业人士来说不是很陌生,翻译一下就是“视图”。在MongoDB之前的版本里面,如果要构造一个集合的子集,个人理解应该有两个办法,一是重新创建一个集合,冗余一下下,还是很方便的。这种方法性能基本没有影响,但是如果数据是动态变化的,同步会有些小小麻烦。二来就是直接操刀用MongoDB聚合框架来完成,不过说实在的,太多中括号、大括号,有时候看的都嫌累。

于是视图腾空出世也非偶然,而且绝对是开“大阳线”的时候了!

在Mongo的视图里,是不存在真正的数据的,可以把它简单的看成是一个“伪集合”。需要访问视图的内容时,视图数据都是通过实时聚合来自于源集合的。很显然,完全没有空间占用问题,这比冗余强的太多。当然也有一个小小例外,就是system.views集合,这里面存放了所有视图的定义内容,好在占不了多少空间。

构建

视图的创建非常简单,db.createView跟着三个参数,第一是视图名,第二是源集合名,第三是聚合条件。于是我们可以创建一个视图包含state为“AL”的所有数据:

然后直接通过db.State_AL进行查询操作,并列举前3条数据。

操作

了解了视图的创建后,到底可以进行哪些操作呢?
一旦视图被创建,就可以对视图进行任何查询操作,操作内容和标准查询操作完全一致,而且可以继续进行聚合框架操作。但是切记,这是只读视图,不能写!当然,还是有些小小限制的,诸如不能用MapReduce,不能用$text进行全文检索等等。
例如在上面State_AL视图之上再次进行聚合,只显示city和zip字段:

场景

实际上产品最有价值的地方不在功能,而是在于是不是有用武之地,这才是其安身立命之地。所以看看MongoDB的视图到底能用在哪里?这才是最关键的!

场景一:扩展安全
我们知道MongoDB的安全性整体相比其他非关系型数据库,整体还是做得不错的,特别是企业版里的增强CRUD升级、加密引擎等等。但是安全和方便基本永远走不到一起,所以配置安全基于角色进行字段级别控制还是需要费些脑细胞的。
能不能让安全简单一些呢?
事实上,视图就是一个不错的方法。假设您有一个数据集合包含了所有的数据,但是我不想把所有的数据都开放给开发人员访问,如信用卡字段、身份证号等等,那么无法进行一个过滤生成一个新的视图,问题就迎刃而解了。
所以简单来说,隔离只读访问是一个不错的视图用例。

场景二:简化逻辑
MongoDB的聚合框架确实不错,而且越来越多的$函数被加入到聚合框架,于是长长的过滤条件写起来还是挺费时间的。但是通过视图,那些被频繁使用的过滤聚合可以被固化下来,那么针对子集的查询会变的更简单、应用逻辑也可简化。
例如假设应用系统要求每个州只能查本地的zip code,那么刚才zip数据里面用$match匹配某一个州的数据的方法就可以非常方便的分割数据,然后继续被应用访问。

暗礁

只读视图确实还是蛮好用的,但是重要的事情需要说三遍,只读、只读、还是只读。尝试写入当然只能接受失败:

另外有几点需要注意一下:
1.动态变化
*视图数据随源集合数据变化而动态变化,因为视图本身并不存放数据,而是实时计算于源数据集合。
*源数据集合被删除时,视图自然得不到任何数据,返回空。
*而当源数据删除后又恢复时,视图又可完全恢复数据。
2.寄生效率
*视图不能提升查询效率,查询效率完全取决于源数据集合内的索引情况,所以视图本身没有效率的决定权。
3.迭代复用
*视图可以建立在一个已有视图上,所以简单来说是可以迭代操作的。

***************************************************************************************************************

练习1:创建视图并排序

db.createView("View_attendData","attendData",[{$match:{"sheetId":"5949f0277d6156d5d4c5740d"}},{$sort:{"data.date":-1}}])

练习2:创建视图并排序、然后选定字段

db.createView("View_attendData","attendData",[{$match:{"sheetId":"5949f0277d6156d5d4c5740d"}},{$project:{"data.date":1,"_id":0}} ,{$sort:{"data.date":-1}}])

时间: 2024-08-24 13:47:54

MongoDB创建视图(十四)的相关文章

【Mongodb教程 第十四课 】MongoDB 投影

mongodb 投影意思是只选择必要的数据而不是选择一个文件的数据的整个.如果一个文档有5个字段,需要显示只有3个,然后选择其中只有3个字段. find() 方法 MongoDB 的find()方法,在 MongoDB查询 文档解释接受第二个可选参数是要检索的字段列表.在MongoDB中,当执行find()方法,那么它会显示一个文档所有字段.要限制这一点,需要设置的字段列表值1或0. 1用来显示字段而0是用来隐藏字段. 语法: find()方法具有投影基本语法如下 >db.COLLECTION_

云计算设计模式(十四)——实体化视图模式

云计算设计模式(十四)——实体化视图模式 产生过在一个或多个数据存储中的数据预填充的观点时,数据被格式化以不利于所需的查询操作的一种方式.这种模式可以帮助支持高效的查询和提取数据,并提高应用程序的性能. 背景和问题 何时存储数据时,优先级为开发者和数据管理员经常集中在如何将数据存储,而不是它是如何读出.所选择的存储格式通常是密切相关的数据,用于管理数据的大小和数据的完整性,并且在使用的那种存储的要求的格式.例如,使用的NoSQL文献商店时,该数据通常被表示为一系列的聚集体,其每一个包含了所有的信

使用delphi 开发多层应用(二十四)KbmMW 的消息方式和创建WIB节点

KbmMW 中支持基于UDP的消息广播,也支持TCP/IP hub/spoke 方式,还有 基于UDP或者TCP/IP 的点对点的消息传输. 1.基于UDP的消息广播 根据UDP  的工作原理,在同一个网段里面,可以发布广播包.这样发布者只需要发布一次, 消息就可以被同一网段上的所有订阅者收到.这样大大的降低了网络带宽.这个方式的最大缺点是 无法直接跨越网段,如果要跨越网段,就需要建立一个Gateway. Gateway 就是一个程序,连接两个网段. 它接受第一个网段的广播消息,然后再广播到第二

Android学习笔记二十四之ListView列表视图二

Android学习笔记二十四之ListView列表视图二 前面一篇我们介绍了常用的几种适配器的简单实现和ListView的简单使用,这一篇中,我们介绍一下ListView的优化和一些其它的问题. ListView优化方法一 在ListView中,我们最常用的就是自定义Adapter,在我们自定义Adapter中,需要实现两个比较重要的方法getCount()和getView(),前者是负责计算ListView的总Item数,后者是生成Item,有多少个Item就会调用getView()方法多少次

iOS 11开发教程(十四)iOS11应用代码添加视图

iOS 11开发教程(十四)iOS11应用代码添加视图 如果开发者想要使用代码为主视图添加视图,该怎么办呢.以下将为开发者解决这一问题.要使用代码为主视图添加视图需要实现3个步骤. (1)实例化视图对象 每一个视图都是一个特定的类.在Swift中,经常会说,类是一个抽象的概念,而非具体的事物,所以要将类进行实例化.实例化一个视图对象的具体语法如下: let/var 对象名=视图类() 以我们接触的第一个视图View为例,它的实例化对象如下: let newView=UIView() 其中,UIV

全栈JavaScript之路( 二十四 )DOM2、DOM3, 不涉及XML命名空间的扩展

(一)DocumentType 类型的变化新增三个属性: publicId,systemId,internalSubset(内部子集) <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" [<!ELEMENT name (#PCDATA)>] > 通过, document.doc

第十四篇 Integration Services:项目转换

本篇文章是Integration Services系列的第十四篇,详细内容请参考原文. 简介在前一篇,我们查看了SSIS变量,变量配置和表达式管理动态值.在这一篇,我们使用SQL Server数据商业智能工具(SSDT-BI)或Visual Studio 2012将我们的第一个SSIS项目转换为SSIS 2012.为什么你想升级我们的SSIS项目到2012?你可能想使用SSIS 2012中的新特性.你可能还希望利用SSIS 2012目录.要使用目录,你的项目必须遵循项目部署模型,我们也将在这篇文

14第十四章触发器(转载)

14第十四章触发器 DML --> AFTER / FOR   UPDATE , INSERT , DELETE  -- 用来级联删除 --> INSTEAD OF  在 时间之前触发,相当于 bef INSERTED, DELETED 两张表要好好利用. 在创建 DML 触发器时,不能使用下列语句: CREATE / ALTER /DROP DATABASE LOAD DATABASE / LOAD LOG / RECONFIGURE RESTORE DATABASE  / RESTORE

我的MYSQL学习心得(十四) 备份和恢复

原文:我的MYSQL学习心得(十四) 备份和恢复 我的MYSQL学习心得(十四) 备份和恢复 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运算符 我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(七) 查询 我的MYSQL学习心得(八) 插入 更新 删除 我的MYSQL学习心得(九) 索引 我的MYSQL学习心得(十) 自定义存储过程