当前位置: 首页 > news >正文

【赵渝强老师】MongoDB的数据类型

1

作为文档型NoSQL数据库的典型代表,MongoDB提供了丰富的数据类型,主要有:ObjectId、String、Boolean、Number、Arrays、Object、Null、Timestamp和Date。下面通过具体的示例来演示其中主要的数据类型以及它们的作用。

image.png
点击这里查看视频讲解:【赵渝强老师】MongoDB的数据类型

一、 ObjectId

ObjectId类似关系型数据库中的主键,MongoDB使用它可以唯一确定集合中的一条文档。ObjectId是一个BSON类型字符串,其中包含了时间戳、机器标识码、进程ID和随机数。因此在分布式环境下,使用ObjectId可以避免MongoDB主键的冲突。当向MongoDB集合中插入文档时,可以通过使用字段_id来指定ObjectId;如果没有指定ObjectId,MongoDB会自动生成ObjectId。

下面通过一个简单的示例来进行演示。
(1)使用mongoshell连接到MongoDB服务器端,并切换到scott数据库中。

$ mongo
test@nosql11 1> use scott

(2)创建一张名叫test1的新集合,并向集合中插入一条文档。

scott@nosql11 2> db.test1.insertOne({name:"Tom",age:25})# 输出的信息如下:
{"acknowledged" : true,"insertedId" : ObjectId("624a559df22c930516afc4e2")
}

(3)查询集合test1中的数据。

scott@nosql11 3> db.test1.find()# 输出的信息如下:
{ "_id" : ObjectId("624a559df22c930516afc4e2"), "name" : "Tom", "age" : 25 }# 由于在第(2)步插入文档时没有指定_id,MongoDB将会为插入的文档自动生成一个ObjectId。

二、 日期类型

在MongoDB中表示日期和时间可以通过Date和Timestamp两种不同的方式进行表示,MongoDB支持使用不同的方式来创建它们。下面通过具体的示例来进行演示。

(1)使用Date()插入一个字符串类型的时间数据。

scott@nosql11 5> Date()
Mon Apr 04 2025 10:37:19 GMT+0800 (CST)

(2)使用new Date()插入一个isodate类型的格林尼治标准时间数据。

scott@nosql11 6> new Date()
ISODate("2025-04-04T02:37:26.813Z")

(3)ISODate()与new Date()方式插入的时间数据类似。

scott@nosql11 7> ISODate()
ISODate("2025-04-04T02:37:35.642Z")

三、 数值类型

MongoDB中表示数值类型的数据时可以使用不同的方式。例如,使用Double表示浮点数;而使用Integer表示一个整数。下面的语句将向MongoDB的表中各插入一个Integer类型和Double类型的数据。

scott@nosql11 12> db.test1.insertOne({x1:1,x2:3.14});

MongoDB还支持使用NumberLong、NumberInt和NumberDecimal来表示数值类型的数据。下表列举了它们之间的区别。

2

下面通过几个具体的示例来演示MongoDB在存储数值类型数据时的区别。
(1)创建一张新集合test2,并向集合中插入下面的测试数据。

scott@nosql11 7> db.test2.insert([{_id:1,val:NumberDecimal('9.99'),Description:'Decimal'},{_id:2,val:9.99,Description:'Double'},{_id:3,val:10,Description:'Double'},{_id:4,val:NumberLong(10),Description:'Long'},{_id:5,val:NumberDecimal('10.0'),Description:'Decimal'}]);

(2)指定下面的查询条件查询集合中的数据。

scott@nosql11 8> db.test2.find({'val':9.99});# 输出的信息如下:
{ "_id" : 2, "val" : 9.99, "Description" : "Double" }# 条件{'val':9.99}将匹配Double类型的9.99;而不是NumberDecimal代表的9.99。

(3)如果要匹配NumberDecimal代表的9.99需要指定下面的查询条件。

scott@nosql11 9> db.test2.find({'val':NumberDecimal('9.99')});# 输出的信息如下:
{ "_id" : 1, "val" : NumberDecimal("9.99"), "Description" : "Decimal" }

(4)指定下面的查询条件查询集合中的数据。

scott@nosql11 10> db.test2.find({'val':10});# 输出的信息如下:
{ "_id" : 3, "val" : 10, "Description" : "Double" }
{ "_id" : 4, "val" : NumberLong(10), "Description" : "Long" }
{ "_id" : 5, "val" : NumberDecimal("10.0"), "Description" : "Decimal" }# 对于整个数字10的匹配,将匹配所有的数据类型10。

(5)指定下面的查询条件查询集合中的数据。

scott@nosql11 11> db.test2.find({'val':NumberDecimal('10')});# 输出的信息如下:
{ "_id" : 3, "val" : 10, "Description" : "Double" }
{ "_id" : 4, "val" : NumberLong(10), "Description" : "Long" }
{ "_id" : 5, "val" : NumberDecimal("10.0"), "Description" : "Decimal" }

四、 其他数据类型

对与MongoDB支持的其他几种数据类型,如String、Boolean、Arrays、Object,下面通过一个简单示例来进行演示。

scott@nosql11 12>  db.test3.insertOne({_id:'stu001',name:'Jone',married:false,age:18,courses:[{cname:'语文',credit:4},{cname:'英语',credit:3}]});# 其中:
# name:   表示姓名,是一个字符串类型的数据。
# married:表示是否结婚,是一个Boolean布尔类型的数据。
# age:    表示年龄,是一个数值类型的数据。
# courses:表示课程列表,是一个数组类型的数据。而数组中的每一个元素又是一个对象,包含课程的名称和学分。
http://www.jsqmd.com/news/113213/

相关文章:

  • 06.cloundflare的使用
  • 计算机图形学|三维变换与变换矩阵
  • 完整教程:Flutter 布局入门
  • 《程序员修炼之道》阅读笔记8
  • CVE-2025-14910:Edimax BR-6208AC路由器路径遍历漏洞深度解析
  • 数据安全新选择:访答本地知识库的隐私守护之道
  • 详细介绍:ThinkPHP 5.1 程序在 Nginx 和 Apache 下的性能对比
  • 实实在在不夸大值得推荐的银川AI搜索优化公司——智美天创
  • 完整教程:CentOS快速安装DockerCE指南
  • 12月19日
  • 英语_阅读_a plan for cancer prevention_待读
  • 【题解】Luogu P3398 仓鼠找 sugar
  • 个人经验记录
  • 女装店铺数据分析系统:从数据预处理到智能推荐的全链路技术实现与深度解析
  • 第二阶段:Android音视频基础 - 教程
  • 聊天软件项目系统设计总结
  • 2025.12.19
  • Day6 链表的基础操作I -卡码网C++基础课
  • 2025年12月篮球场运动木地板,实木运动木地板,枫木运动木地板厂家推荐,高性能与可靠性兼具的优质品牌 - 品牌鉴赏师
  • 完整教程:xorrisofs的系统架构与开源地址
  • P1657 选书
  • RPA在财务领域的应用,重塑管理会计发展格局 - 详解
  • 汉默斯问鼎厨卫峰会双奖:中餐厨余处理器创新突围,以用户痛点锚定产业新坐标
  • 峰会收官传捷报!金当汉默斯创新实力获认可,一举拿下“重磅新品”“人气飙升”双项殊荣
  • 2.面向对象设计原则
  • Day6 16. 位置互换 -卡码网C++基础课
  • Java毕业设计如何顺利凭借
  • 自己写的库:rstiff:高精度、类型保留的 Rust GeoTiff 处理库
  • langfuse-LLM 模版评估选择
  • 升级二进制kubernetes集群(大版本升级)