虽然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安装、基础操作和聚合实例详解的更多相关文章

  1. C#操作SQLite方法实例详解

    用 C# 访问 SQLite 入门(1) CC++C#SQLiteFirefox  用 C# 访问 SQLite 入门 (1) SQLite 在 VS C# 环境下的开发,网上已经有很多教程.我也是从 ...

  2. MongoDB安装+基础操作

    MongoDB 一. 安装 这里展示使用docker安装mongoDB 拉取最新MongoDB镜像 docker pull mongo 运行容器 docker run -itd --name mong ...

  3. linux基础-磁盘阵列(RAID)实例详解

    磁盘阵列(RAID)实例详解 raid技术分类 软raid技术 硬raid技术 Raid和lvm的区别 为什么选择用raid RAID详解 RAID-0 RAID-1 RAID-5 Raid-10 R ...

  4. java 流操作对文件的分割和合并的实例详解_java - JAVA

    文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 java 流操作对文件的分割和合并的实例详解 学习文件的输入输出流,自己做一个小的示例,对文件进行分割和合并. 下面是代 ...

  5. Python编程之列表操作实例详解【创建、使用、更新、删除】

    Python编程之列表操作实例详解[创建.使用.更新.删除] 这篇文章主要介绍了Python编程之列表操作,结合实例形式分析了Python列表的创建.使用.更新.删除等实现方法与相关操作技巧,需要的朋 ...

  6. Cocos2d-x 3.X手游开发实例详解

    Cocos2d-x 3.X手游开发实例详解(最新最简Cocos2d-x手机游戏开发学习方法,以热门游戏2048.卡牌为例,完整再现手游的开发过程,实例丰富,代码完备,Cocos2d-x作者之一林顺和泰 ...

  7. 转载 《AngularJS》5个实例详解Directive(指令)机制

    <AngularJS>5个实例详解Directive(指令)机制 大漠穷秋 本文整理并扩展了<AngularJS>这本书第六章里面的内容,此书近期即将由电子工业出版社出版,敬请 ...

  8. 【python3+request】python3+requests接口自动化测试框架实例详解教程

    转自:https://my.oschina.net/u/3041656/blog/820023 [python3+request]python3+requests接口自动化测试框架实例详解教程 前段时 ...

  9. python+requests接口自动化测试框架实例详解

    python+requests接口自动化测试框架实例详解   转自https://my.oschina.net/u/3041656/blog/820023 摘要: python + requests实 ...

  10. Tomcat系列之服务器的安装与配置以及各组件详解

    Tomcat系列之服务器的安装与配置以及各组件详解 大纲 一.前言 二.安装与配置Tomcat 三.Tomcat 目录的结构 四.Tomcat 配置文件 注,本文的测试的操作系统为CentOS 6.4 ...

随机推荐

  1. kettle使用2-增量插入

    1.新建转换 2.在DB连接中,新建2个数据库连接 3.在输入中,新建:表输入 4.在输入中,新建:表输入 5.在输出中,新建:表输出

  2. Mark Lee:Splashtop 如何成为最新的 10 亿美元估值技术独角兽

    从左至右:Splashtop联合创始人Rob.Philip.Mark和Thomas Splashtop 刚刚完成了由我们的长期投资者 Sapphire Ventures 领投的 5000 万美元的新融 ...

  3. 字节面试:说说Java中的锁机制?

    Java 中的锁(Locking)机制主要是为了解决多线程环境下,对共享资源并发访问时的同步和互斥控制,以确保共享资源的安全访问. 锁的作用主要体现在以下几个方面: 互斥访问:确保在任何时刻,只有一个 ...

  4. fuser命令详解

    fuser -mv 作用 fuser命令是用来显示所有正在使用着指定的file.file system或者sockets的进程信息.具体来说,fuser -mv的作用如下: 参数-m:指定一个被加载的 ...

  5. k8s错误集合

    1.etcd没有启动的 [root@mcwk8s03 ~]# kubectl get nodesUnable to connect to the server: context deadline ex ...

  6. 组合数学:Burnside引理和Polya定理解决染色置换问题

    例题 给3x3的格子上色,4种颜色,可以重复.排除旋转后相同的情况,请问有多少种不同的上色方法? 解答 设格子编号如下: | 1 | 2 | 3 | | 4 | 5 | 6 | | 7 | 8 | 9 ...

  7. XML Schema 字符串数据类型及约束详解

    字符串数据类型用于包含字符字符串的值.字符串数据类型可以包含字符.换行符.回车符和制表符. 以下是模式中字符串声明的示例: <xs:element name="customer&quo ...

  8. Wakeup Source框架设计与实现

    Wakeup Source 为系统组件提供了投票机制,以便低功耗子系统判断当前是否可以进入休眠. Wakeup Source(后简称:WS) 模块可与内核中的其他模块或者上层服务交互,并最终体现在对睡 ...

  9. 箭头函数中的this指向

        // 箭头函数中的this指向         //     如果是箭头函数,this指向是,父级程序的,this的指向         //       如果父级程序是一个函数,函数也是有t ...

  10. kettle从入门到精通 第十八课 kettle Metadata Injection

    1.Metadata Injection 类似于java里面的模版,设置通用的模版,通过输入不同的数据,得到不同的结果.本示例演示两个字段拼接成一个新字段. 2.设置模版,设置模版时,只需要根据自己的 ...