MongoDB 是一种流行的 NoSQL 数据库,是许多应用程序的首选数据库。MongoDB 提供了丰富的功能,以及与其他技术的无缝集成。MongoDB 可以通过命令行(Mongo shell)进行操作,本文将分享一些 MongoDB 命令行操作的实用技巧。
1. 连接 MongoDB
要利用 MongoDB 命令行进行操作,首先需要与 MongoDB 进行连接。
# 如果 MongoDB 运行在本地主机上默认端口(27017) mongo
如果 MongoDB 不在本地主机或使用了不同的端口或需要身份验证,则需要使用下面的命令连接:
mongo --host <hostname>:<port> --authenticationDatabase <auth-db> -u <username> -p<password>
其中:
<hostname>
:MongoDB 服务器的主机名或 IP 地址。<port>
:MongoDB 服务器的端口号,默认为 27017。<auth-db>
:MongoDB 鉴权的数据库。如果不指定,则默认为 admin。<username>
:MongoDB 用户名。<password>
:MongoDB 密码。
2. 显示数据集
在 MongoDB 中,数据存储在数据集(collection)中。使用以下命令显示所选择的数据库中的所有数据集。
show collections
输出示例:
books users videos
3. 查询数据
使用以下命令查询一个数据集中的所有文档。
db.<collection>.find()
其中 <collection>
为数据集的名称。例如,要在名为 books 的数据集中查找所有文档,可以使用以下命令:
db.books.find()
如果需要输入更多的查询条件,可以使用以下命令:
db.<collection>.find(<query>)
其中 <query>
是一个 JavaScript 对象,表示查询条件。例如,要查找名为 "MongoDB 教程" 的书籍,可以使用以下命令:
db.books.find({ title: "MongoDB 教程" })
4. 更新数据
可以使用以下命令更新数据集中的文档。
db.<collection>.update(<query>, <update>)
其中 <query>
是一个 JavaScript 对象,表示要更新的文档。 <update>
表示要更新的字段。例如,要将名为 books 的数据集中所有作者为 "Tom" 的书籍的价格增加 10,可以使用以下命令:
db.books.update({ author: "Tom" }, { $inc: { price: 10 } }, { multi: true })
其中,$inc
等操作符可用于对查询结果应用数学运算。multi: true
表示更新所有符合条件的文档,而非只更新第一个匹配的文档。
5. 聚合数据
MongoDB 可以对数据集中的文档进行聚合操作,并返回聚合结果。以下是一些聚合操作示例:
5.1 统计文档数量
db.<collection>.count()
例如,要查询数据集 books 中的文档数量,可以使用以下命令:
db.books.count()
5.2 分组统计
可以使用 $group
操作符对数据集中的文档进行分组,并统计每个组内的文档数量。
db.<collection>.aggregate([{$group: {_id: <field-to-group-by>, count: {$sum: 1}}}])
例如,要按照作者对数据集 books 中的文档进行分组,并统计每个作者的书籍数量,可以使用以下命令:
db.books.aggregate([{$group: {_id: "$author", count: {$sum: 1}}}])
6. 导入和导出数据
可以使用 mongoimport
命令将数据从文件导入到 MongoDB 中。
mongoimport --db <db name> --collection <collection name> --file <file name>
其中 <db name>
、<collection name>
和 <file name>
分别是数据库名称、数据集名称和要导入的文件名称。
可以使用 mongoexport
命令将 MongoDB 数据集中的数据导出到文件中。
mongoexport --db <db name> --collection <collection name> --out <file name>
其中 <db name>
、<collection name>
和 <file name>
分别是数据库名称、数据集名称和要导出的文件名称。
结论
本文介绍了一些 MongoDB 命令行操作的实用技巧,主要涵盖了连接 MongoDB、显示数据集、查询数据、更新数据、聚合数据、导入和导出数据等方面。通过掌握这些技巧,可以更轻松地操作 MongoDB 数据库。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6735c4120bc820c582505bbb