MongoDB安装、基础操作和聚合实例详解
虽然MongoDB这些年很流行,但笔者之前没研究过,现在有需求研究这类NoSQL的数据库,是为了验证其是否可被替换。

MongoDB是很轻量的文档数据库,简单测试也懒得专门准备虚拟机环境了,直接在macOS上安装测试下其基础功能。
- 1.使用 Homebrew 安装 MongoDB
- 2.启动/停止 MongoDB 服务
- 3.启动 MongoDB Shell
- 4.体验 MongoDB 基本操作
- 5.体验 MongoDB 聚合操作
1. 使用 Homebrew 安装 MongoDB
# 添加 MongoDB 存储库
brew tap mongodb/brew
# 安装 MongoDB 社区版
brew install mongodb-community
2. 启动/停止 MongoDB 服务
# 启动 MongoDB 服务
brew services start mongodb/brew/mongodb-community
# 停止 MongoDB 服务(这个当然要等我们体验测试完成后才停..)
brew services stop mongodb/brew/mongodb-community
3. 启动 MongoDB Shell
# 打开 MongoDB 的交互式 Shell
mongosh
在mongosh登录到MongoDB时可以看到,笔者这里安装的是7.0.12版本的MongoDB,使用默认端口27017:
jingyuzhao@jingyuzhao-mac ~ % mongosh
Current Mongosh Log ID: 668ce3d3012a1d349d3a46b3
Connecting to: mongodb://127.0.0.1:27017/?directConnection=true&serverSelectionTimeoutMS=2000&appName=mongosh+2.2.10
Using MongoDB: 7.0.12
Using Mongosh: 2.2.10
For mongosh info see: https://docs.mongodb.com/mongodb-shell/
------
The server generated these startup warnings when booting
2024-07-09T15:09:54.021+08:00: Access control is not enabled for the database. Read and write access to data and configuration is unrestricted
------
test>
4. 体验MongoDB基本操作
下面进行一些基本的 MongoDB 操作示例:
1)创建数据库和集合:
-- 切换到要使用的数据库(如果不存在则会自动创建)
use mydb
-- 创建集合
db.createCollection("myCollection")
2)插入文档:
-- 插入单个文档:
db.myCollection.insertOne({ name: "Alfred", age: 34 })
-- 插入多个文档:
db.myCollection.insertMany([
{ name: "Mcdull", age: 33 },
{ name: "Sally", age: 4 }
])
3)查询文档:
-- 查询所有文档:
db.myCollection.find()
-- 查询满足条件的文档:
db.myCollection.find({ age: { $gt: 25 } })
4)更新文档:
-- 更新单个文档:
db.myCollection.updateOne({ name: "Alfred" }, { $set: { age: 29 } })
-- 更新多个文档:
db.myCollection.updateMany({ age: { $lt: 35 } }, { $set: { status: "Active" } })
5)删除文档:
-- 删除单个文档,name值为'Sally'的记录:
db.myCollection.deleteOne({ name: "Sally" })
-- 删除多个文档,status值为'Active'的记录:
db.myCollection.deleteMany({ status: "Active" })
5. 体验MongoDB聚合操作
1)创建测试用例
-- 删除 sales 集合
db.sales.drop()
-- 创建 sales 集合并插入示例文档
db.sales.insertMany([
{
"order_id": 1001,
"product": "Laptop",
"quantity": 2,
"unit_price": 1200,
"customer": "Alice",
"order_date": ISODate("2024-06-07T08:30:00Z")
},
{
"order_id": 1002,
"product": "Monitor",
"quantity": 1,
"unit_price": 500,
"customer": "Bob",
"order_date": ISODate("2024-06-10T10:15:00Z")
},
{
"order_id": 1003,
"product": "Keyboard",
"quantity": 3,
"unit_price": 50,
"customer": "Alice",
"order_date": ISODate("2024-06-15T14:45:00Z")
},
{
"order_id": 1004,
"product": "Mouse",
"quantity": 5,
"unit_price": 20,
"customer": "Charlie",
"order_date": ISODate("2024-07-09T09:30:00Z")
}
])
查询这个集合结果:
db.sales.find()
mydb> db.sales.find()
[
{
_id: ObjectId('668cf766749a72317b175646'),
order_id: 1001,
product: 'Laptop',
quantity: 2,
unit_price: 1200,
customer: 'Alice',
order_date: ISODate('2024-06-07T08:30:00.000Z')
},
{
_id: ObjectId('668cf766749a72317b175647'),
order_id: 1002,
product: 'Monitor',
quantity: 1,
unit_price: 500,
customer: 'Bob',
order_date: ISODate('2024-06-10T10:15:00.000Z')
},
{
_id: ObjectId('668cf766749a72317b175648'),
order_id: 1003,
product: 'Keyboard',
quantity: 3,
unit_price: 50,
customer: 'Alice',
order_date: ISODate('2024-06-15T14:45:00.000Z')
},
{
_id: ObjectId('668cf766749a72317b175649'),
order_id: 1004,
product: 'Mouse',
quantity: 5,
unit_price: 20,
customer: 'Charlie',
order_date: ISODate('2024-07-09T09:30:00.000Z')
}
]
mydb>
2)执行聚合操作
示例 1: 计算每个客户的总销售额和订单数量
db.sales.aggregate([
{
$group: {
_id: "$customer",
totalSales: { $sum: { $multiply: ["$quantity", "$unit_price"] } },
totalOrders: { $sum: 1 }
}
},
{ $sort: { totalSales: -1 } } // 按总销售额降序排序
])
查询结果:【计算每个客户的总销售额和订单数量】
[
{ _id: 'Alice', totalSales: 2550, totalOrders: 2 },
{ _id: 'Bob', totalSales: 500, totalOrders: 1 },
{ _id: 'Charlie', totalSales: 100, totalOrders: 1 }
]
示例 2: 查找每种产品的平均销售价格和销售数量
db.sales.aggregate([
{
$group: {
_id: "$product",
avgPrice: { $avg: "$unit_price" },
totalQuantity: { $sum: "$quantity" }
}
},
{ $sort: { _id: 1 } } // 按产品名称升序排序
])
查询结果:【查找每种产品的平均销售价格和销售数量】
[
{ _id: 'Keyboard', avgPrice: 50, totalQuantity: 3 },
{ _id: 'Laptop', avgPrice: 1200, totalQuantity: 2 },
{ _id: 'Monitor', avgPrice: 500, totalQuantity: 1 },
{ _id: 'Mouse', avgPrice: 20, totalQuantity: 5 }
]
示例 3: 筛选特定日期范围内的销售订单并投影字段
db.sales.aggregate([
{
$match: {
order_date: {
$gte: ISODate("2024-06-01"),
$lte: ISODate("2024-06-30")
}
}
},
{
$project: {
order_id: 1,
product: 1,
quantity: 1,
totalAmount: { $multiply: ["$quantity", "$unit_price"] }
}
}
])
查询结果:【筛选特定日期范围内的销售订单并投影字段】
[
{
_id: ObjectId('668cf766749a72317b175646'),
order_id: 1001,
product: 'Laptop',
quantity: 2,
totalAmount: 2400
},
{
_id: ObjectId('668cf766749a72317b175647'),
order_id: 1002,
product: 'Monitor',
quantity: 1,
totalAmount: 500
},
{
_id: ObjectId('668cf766749a72317b175648'),
order_id: 1003,
product: 'Keyboard',
quantity: 3,
totalAmount: 150
}
]
至此,我们学习了如何安装、启动和停止 MongoDB,并通过 MongoDB Shell 执行基础的 CRUD 操作(创建、查询、更新和删除文档),同时探索了 MongoDB 的聚合操作,用于实现复杂的数据分析。后续,会继续研究关于Oracle 23ai在JSON这方面的能力表现。
MongoDB安装、基础操作和聚合实例详解的更多相关文章
- C#操作SQLite方法实例详解
用 C# 访问 SQLite 入门(1) CC++C#SQLiteFirefox 用 C# 访问 SQLite 入门 (1) SQLite 在 VS C# 环境下的开发,网上已经有很多教程.我也是从 ...
- MongoDB安装+基础操作
MongoDB 一. 安装 这里展示使用docker安装mongoDB 拉取最新MongoDB镜像 docker pull mongo 运行容器 docker run -itd --name mong ...
- linux基础-磁盘阵列(RAID)实例详解
磁盘阵列(RAID)实例详解 raid技术分类 软raid技术 硬raid技术 Raid和lvm的区别 为什么选择用raid RAID详解 RAID-0 RAID-1 RAID-5 Raid-10 R ...
- java 流操作对文件的分割和合并的实例详解_java - JAVA
文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 java 流操作对文件的分割和合并的实例详解 学习文件的输入输出流,自己做一个小的示例,对文件进行分割和合并. 下面是代 ...
- Python编程之列表操作实例详解【创建、使用、更新、删除】
Python编程之列表操作实例详解[创建.使用.更新.删除] 这篇文章主要介绍了Python编程之列表操作,结合实例形式分析了Python列表的创建.使用.更新.删除等实现方法与相关操作技巧,需要的朋 ...
- Cocos2d-x 3.X手游开发实例详解
Cocos2d-x 3.X手游开发实例详解(最新最简Cocos2d-x手机游戏开发学习方法,以热门游戏2048.卡牌为例,完整再现手游的开发过程,实例丰富,代码完备,Cocos2d-x作者之一林顺和泰 ...
- 转载 《AngularJS》5个实例详解Directive(指令)机制
<AngularJS>5个实例详解Directive(指令)机制 大漠穷秋 本文整理并扩展了<AngularJS>这本书第六章里面的内容,此书近期即将由电子工业出版社出版,敬请 ...
- 【python3+request】python3+requests接口自动化测试框架实例详解教程
转自:https://my.oschina.net/u/3041656/blog/820023 [python3+request]python3+requests接口自动化测试框架实例详解教程 前段时 ...
- python+requests接口自动化测试框架实例详解
python+requests接口自动化测试框架实例详解 转自https://my.oschina.net/u/3041656/blog/820023 摘要: python + requests实 ...
- Tomcat系列之服务器的安装与配置以及各组件详解
Tomcat系列之服务器的安装与配置以及各组件详解 大纲 一.前言 二.安装与配置Tomcat 三.Tomcat 目录的结构 四.Tomcat 配置文件 注,本文的测试的操作系统为CentOS 6.4 ...
随机推荐
- .NET实现获取NTP服务器时间并同步(附带Windows系统启用NTP服务功能)
对某个远程服务器启用和设置NTP服务(Windows系统) 打开注册表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Tim ...
- SpringMVC在处理Ajax请求后返回void导致前台Ajax回调函数不执行
问题简述 在一次SpringMVC项目中,前台通过Ajax请求,准备修改数据库中的数据.因为Ajax请求只是让后台更改数据,所以Controller方法根本不需要返回给前台任何数据,所以我们将Cont ...
- 使用爬虫利器 Playwright,轻松爬取抖查查数据
使用爬虫利器 Playwright,轻松爬取抖查查数据 我们先分析登录的接口,其中 url 有一些非业务参数:ts.he.sign.secret. 然后根据这些参数作为关键词,定位到相关的 js 代码 ...
- jquery 给表格添加或删除一行
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Qt-FFmpeg开发-视频播放(4)
音视频/FFmpeg #Qt Qt-FFmpeg开发-视频播放[软解码 + OpenGL显示YUV420P图像] 目录 音视频/FFmpeg #Qt Qt-FFmpeg开发-视频播放[软解码 + Op ...
- FFMPEG 信息查询
一.问题描述 最近测试反馈一个隐私模式的问题,主播端启用隐私模式之后,在观看端发现画面转菊花并且还有回跳的现象 二.问题分析: 从网上下载了直播的视频文件,进行了一下分析,发现视频长度和音频长度不匹配 ...
- 15种pod的状态
15种pod的状态 调度失败 常见错误状态(Unschedulable) pod被创建后进入调度阶段,k8s调度器依据pod声明的资源请求量和调度规则,为pod挑选一个适合运行的节点.当集群节点不满足 ...
- The solution of P5339
problem 容斥好题,结果题解里面一堆 \(\text{NTT}\). 如果我们去掉有多少个人喜欢什么东西的条件,那么这个题就直接枚举有 \(i\) 组同学会一起讨论蔡徐坤.这一个问题十分容易. ...
- 错误 CS1617 Invalid option '7.3' for /langversion; must be ISO-1, ISO-2, Default or an integer in range 1 to 6.
严重性 代码 说明 项目 文件 行 禁止显示状态错误 CS1617 Invalid option '7.3' for /langversion; must be ISO-1, ISO-2, Defau ...
- 微信实名认证申请单报错:请求中含有未在API文档中定义的参数
完整错误: {"code":"PARAM_ERROR","detail":{"location":null," ...