MongoDB聚合: $redact

2024-02-12 11:20
文章标签 mongodb 聚合 redact

本文主要是介绍MongoDB聚合: $redact,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

$redact阶段可以根据文档本身存储的信息,限制输出整个文档或文档中的内容。

语法

{ $redact: <expression> }

使用

参数可以是任何有效的表达式,只要能被解析为$$DESCEND$$PRUNE$$KEEP系统变量即可。

$$DESCEND

$redact返回当前文档级别的字段,不包括嵌入文档。若要包含嵌入文档和数组中的嵌入文档,需要对嵌入文档应用$cond表达式,以确定这些嵌入文档的访问权限。

$$PRUNE

$redact排除当前/嵌入文档级别的所有字段,无需进一步检查任何排除字段,即使排除的字段包含可能具有不同访问级别的嵌入文档。

$$KEEP

$redact返回或保留当前/嵌入文档级别的所有字段,而无需进一步检查该级别的字段。即使包含的字段包含可能具有不同访问级别的嵌入文档。

举例

评估每个文档级别的访问权限

forecasts集合包含以下形式的文档,其中tags字段列出了该文档/嵌入式文档级别的不同访问值;例如,[ "G"、"STLW" ]表示"G""STLW"可以访问数据:

{_id: 1,title: "123 Department Report",tags: [ "G", "STLW" ],year: 2014,subsections: [{subtitle: "Section 1: Overview",tags: [ "SI", "G" ],content:  "Section 1: This is the content of section 1."},{subtitle: "Section 2: Analysis",tags: [ "STLW" ],content: "Section 2: This is the content of section 2."},{subtitle: "Section 3: Budgeting",tags: [ "TK" ],content: {text: "Section 3: This is the content of section 3.",tags: [ "HCS" ]}}]
}

用户有权查看"STLW"或"G"的信息,要对该用户2014年的所有文档进行查询,可以在查询时加入$redact阶段:

var userAccess = [ "STLW", "G" ];
db.forecasts.aggregate([{ $match: { year: 2014 } },{ $redact: {$cond: {if: { $gt: [ { $size: { $setIntersection: [ "$tags", userAccess ] } }, 0 ] },then: "$$DESCEND",else: "$$PRUNE"}}}]
);

聚合操作返回下面"编辑后"的文档:

{"_id" : 1,"title" : "123 Department Report","tags" : [ "G", "STLW" ],"year" : 2014,"subsections" : [{"subtitle" : "Section 1: Overview","tags" : [ "SI", "G" ],"content" : "Section 1: This is the content of section 1."},{"subtitle" : "Section 2: Analysis","tags" : [ "STLW" ],"content" : "Section 2: This is the content of section 2."}]
}

排除指定级别的所有字段

accounts集合有下列文档:

{_id: 1,level: 1,acct_id: "xyz123",cc: {level: 5,type: "yy",num: 000000000000,exp_date: ISODate("2015-11-01T00:00:00.000Z"),billing_addr: {level: 5,addr1: "123 ABC Street",city: "Some City"},shipping_addr: [{level: 3,addr1: "987 XYZ Ave",city: "Some City"},{level: 3,addr1: "PO Box 0123",city: "Some City"}]},status: "A"
}

在这个示例文档中,level字段决定了查看数据所需的访问级别。

要在状态为A的所有文档上运行查询,并排除级别为5的文档/嵌入式文档中包含的所有字段,可在查询时加入$redact阶段,在then字段中指定系统变量"$$PRUNE"

db.accounts.aggregate([{ $match: { status: "A" } },{$redact: {$cond: {if: { $eq: [ "$level", 5 ] },then: "$$PRUNE",else: "$$DESCEND"}}}]
);

$redact阶段会评估level字段以确定访问权限,如果level字段等于5,则排除该级别的所有字段,即使排除的字段包含可能具有不同级别值的嵌入文档,如shipping_addr字段。

聚合操作会返回下面的文档:

{"_id" : 1,"level" : 1,"acct_id" : "xyz123","status" : "A"
}

结果显示$redact阶段排除了整个cc字段,包括shipping_addr字段,该字段包含的嵌入文档的级别字段值等于3而不是5

这篇关于MongoDB聚合: $redact的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/702487

相关文章

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

ElasticSearch的DSL查询⑤(ES数据聚合、DSL语法数据聚合、RestClient数据聚合)

目录 一、数据聚合 1.1 DSL实现聚合 1.1.1 Bucket聚合  1.1.2 带条件聚合 1.1.3 Metric聚合 1.1.4 总结 2.1 RestClient实现聚合 2.1.1 Bucket聚合 2.1.2 带条件聚合 2.2.3 Metric聚合 一、数据聚合 聚合(aggregations)可以让我们极其方便的实现对数据的统计、分析、运算。例如:

七、Maven继承和聚合关系、及Maven的仓库及查找顺序

1.继承   2.聚合   3.Maven的仓库及查找顺序

生产mongodb 分片与集群 方案

链接:http://my.oschina.net/pwd/blog/411439#navbar-header 注:主要是有一键安装的脚本可以借鉴

mongodb基本命令和Java操作API示例

1.Mongo3.2 java API示例:http://www.cnblogs.com/zhangchaoyang/articles/5146508.html 2.MongoDB基本命:http://www.cnblogs.com/xusir/archive/2012/12/24/2830957.html 3.java MongoDB查询(一)简单查询: http://www.cnblogs

使用jetty和mongodb做个简易文件系统

使用jetty和mongodb做个简易文件系统 - ciaos 时间 2014-03-09 21:21:00   博客园-所有随笔区 原文   http://www.cnblogs.com/ciaos/p/3590662.html 主题  MongoDB  Jetty  文件系统 依赖库: 1,jetty(提供http方式接口) 2,mongodb的java驱动(访问mo

mongodb简单入门

一篇较好的mongodb常用操作命令:http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html mongodb的java操作:http://www.cnblogs.com/cyhe/p/5451421.html

mongodb自启动脚本.md

可粘贴文本(不全): #!/bin/sh##chkconfig: 2345 80 90#description:mongodb#processname:mongodbif test -f /sys/kernel/mm/transparent_hugepage/enabled; thenecho never > /sys/kernel/mm/transparent_hugepage/e