Mongodb聚合操作中的$type

在mongodb查询语句中,用户可以通过指定type值,查询出的符合字段类型的文档数据。在mongodb聚合操作中,也存在type操作符。本文就聚合操作中的$type进行介绍。

定义

返回一个表示传入参数BSON类型的字符串。在聚合操作中,按照下面的语法来返回类型信息

复制代码
{$type: <expression>}

其中,expression可以是字段名称,运算等任何合法的表达式。

行为

与查询过滤器中的type用法不同。聚合操作中的type用来返回表达式中的结果类型。如当传入一个数组作为参数是,返回数组类型。

当指定字段名称作为参数时,当文档中不存在该字段时,$type返回字符串"missing"。

下面表格描述了传入不同参数时获取到的结果。

|----------------------------|----------|
| 表达式 | 结果 |
| {type: "a"} | "string" | | {type: /a/} | "regex" |
| {type: 1} | "double" | | {type: NumberLong(627)} | "long" |
| {type: {x: 1}} | "object" | | {type: \[1, 2, 3 ]} | "array" |

其中,为了避免数组1, 2, 3被解析成参数列表,这里将数组转换成了字面意义。

应用

在集合coll中有下面6个文档。

复制代码
db.coll.insertMany([
    {_id: 0, a: 8},
    {_id: 1, a: [ 41.63, 88.19]},
    {_id: 2, a: {a: "apple", b: "banana", c: "carrot"}},
    {_id: 3, a: "caribou"},
    {_id: 4, a: NumberLong(71)},
    {_id: 5},
    ])

使用聚合查询,查询字段a的类型

复制代码
db.coll.aggregate([{
    $project: {
        a: {$type: "$a"}
    }
}])

/* 1 */
{
	"_id" : 0,
	"a" : "int"
},

/* 2 */
{
	"_id" : 1,
	"a" : "array"
},

/* 3 */
{
	"_id" : 2,
	"a" : "object"
},

/* 4 */
{
	"_id" : 3,
	"a" : "string"
},

/* 5 */
{
	"_id" : 4,
	"a" : "long"
},

/* 6 */
{
	"_id" : 5,
	"a" : "missing"
}

再来试试上面举例中返回数组的类型。直接传入数组时, mongodb返回了一个错误。 mongodb把直接传入的数组解析成了3个参数。而$type只能接受一个参数

复制代码
//直接传入一个数组
db.coll.aggregate([{
    $project: {
        a: {$type: [1,2,3]}
    }
}])
{
	"message" : "Invalid $project :: caused by :: Expression $type takes exactly 1 arguments. 3 were passed in.",
	"ok" : 0,
	"code" : 16020,
	"codeName" : "Location16020"
}

因此我们需要将数组的字面意义作为表达式传递给$type作为参数。

复制代码
db.coll.aggregate([{
    $project: {
        a: {$type: {$literal: [1,2,3]}} //使用$literal传递数组的字面意义,不要被解析
    }
}])

或者把数组整体作为一个参数,传递给$type

复制代码
db.coll.aggregate([{
    $project: {
        a: {$type: [[1,2,3]]}
    }
}])

这里, $type后面是一个数组,数组中只有一个元素是1,2,3的数组。当mongodb解析时,得到这个数组作为参数。

相关推荐
Elastic 中国社区官方博客1 分钟前
使用 Jina CLIP v2 和 Elasticsearch 实现多语言图片搜索
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·jina
列星随旋5 分钟前
矩阵快速幂
java·算法·矩阵
闪电悠米5 分钟前
黑马点评-分布式锁-02_simple_redis_lock_setnx
java·数据库·spring boot·redis·分布式·缓存·wpf
数据库小学妹6 分钟前
数据库高可用架构实战:从主从复制到两地三中心的四层演进与避坑
数据库·经验分享·架构·dba
z200509307 分钟前
今日算法(回溯全排列)
c++·算法·leetcode
Boom_Shu8 分钟前
构造函数程序
数据结构·算法
Gong-Yu11 分钟前
MySQL数据库运维(1)
运维·数据库·mysql·慢查询
柏舟飞流14 分钟前
StarRocks: 新一代极速全场景MPP数据库
数据库
MicroTech202515 分钟前
微算法科技(NASDAQ: MLGO)量子安全与区块链:量子神经网络QNN赋能动态共识与量子密钥分发
科技·算法·安全
Database_Cool_22 分钟前
阿里云 AnalyticDB MySQL 免运维实践:分析型数据库不需要专人运维
数据库·数据仓库·mysql·阿里云