MongoDB从0到1:高效数据使用方法

        MongoDB,作为一种流行的NoSQL数据库。从基础的文档存储到复杂的聚合查询,从索引优化到数据安全都有其独特之处。文末附MongoDB常用命令大全。

目录

1. 引言

MongoDB简介

MongoDB的优势和应用场景

2. 基础篇

安装和配置MongoDB

MongoDB基本概念

使用MongoDB Shell

3. 数据库操作

创建和删除数据库

切换数据库

查看当前数据库状态

4. 集合操作

创建集合与设置选项

列出所有集合

删除集合

5. 文档操作

插入文档

查询文档

更新文档

删除文档

6. 高级查询

比较操作符

逻辑操作符

数组操作符

7. 索引管理

创建索引

管理和优化索引

8. 聚合与分析

聚合操作简介

聚合管道

9. 备份与恢复

备份数据的重要性

使用mongodump和mongorestore

10. 数据导入导出

使用mongoimport和mongoexport

11. 安全与权限管理

配置访问控制

用户和角色管理

MongoDB常用命令大全

查询操作


1. 引言

MongoDB简介

        MongoDB是一种面向文档的NoSQL数据库,由于其高性能、高可用性和易扩展性,它已经成为了大数据和实时Web应用的热门选择。与传统的表格型数据库不同,MongoDB使用文档(通常是JSON样式)来存储数据,这使得数据的存储更加灵活和直观。

MongoDB的优势和应用场景

        MongoDB的主要优势包括其模式自由的文档模型、强大的查询语言、高性能、高可用的复制特性以及水平扩展能力。它广泛应用于内容管理、移动和社交应用、实时分析等多个领域。

2. 基础篇

安装和配置MongoDB

        MongoDB的安装相对简单,可以从MongoDB官网下载对应操作系统的安装包进行安装。对于大多数开发者来说,推荐使用默认配置即可开始。在安装完成后,你可以通过启动mongod进程来运行MongoDB服务器。

MongoDB基本概念
  • 数据库(Database):数据库是存储集合的物理容器。一个MongoDB实例可以承载多个数据库。
  • 集合(Collection):集合类似于传统数据库中的表,是存储文档的地方。一个集合中的文档可以有不同的字段,但通常都是为了同一目的或主题而收集的。
  • 文档(Document):文档是MongoDB中数据的基本单位,类似于JSON对象,具有键值对的结构。
使用MongoDB Shell

        MongoDB Shell是一个交互式JavaScript接口,用于操作MongoDB。通过Shell,你可以执行查询、更新数据、管理数据库操作等。例如,使用show dbs命令可以列出所有数据库。

3. 数据库操作

创建和删除数据库

        要创建一个数据库,首先使用use <database_name>命令切换到该数据库。如果数据库不存在,MongoDB会在你第一次向其中写入数据时自动创建它。

        删除数据库使用db.dropDatabase()命令,在执行之前确保你在正确的数据库上下文中。

切换数据库

        使用use <database_name>命令可以切换当前的数据库上下文到指定的数据库。

查看当前数据库状态

   db.stats()命令可以显示当前数据库的状态信息,如数据大小、集合数量等。

4. 集合操作

        MongoDB中的集合类似于传统关系数据库中的表,但它不需要定义固定的表结构,这使得MongoDB非常灵活。

创建集合与设置选项

        创建集合可以使用db.createCollection(name, options)命令,其中name是你想要创建的集合名称,options是一个文档,用来指定集合的配置。例如,以下命令创建一个名为myCollection的集合,具有最大文档数限制和最大存储空间限制:

db.createCollection("myCollection", { capped : true, size : 5242880, max : 5000 } )

这里,capped表示创建一个固定大小的集合,size指定最大大小,max指定最大文档数量。

列出所有集合

        要查看数据库中所有的集合,可以使用show collections命令。这个命令会列出当前数据库中所有集合的名称。

删除集合

        如果你需要删除一个集合及其所有数据,可以使用db.<collection>.drop()命令。例如,要删除myCollection集合:

db.myCollection.drop()

5. 文档操作

文档是MongoDB中存储数据的基本单位,类似于JSON对象的结构。

插入文档
  • 插入单个文档:使用db.<collection>.insertOne(document)命令,如:

    db.myCollection.insertOne({ name: "John", age: 30, city: "New York" })
  • 插入多个文档:使用db.<collection>.insertMany([documents])命令,如:

    db.myCollection.insertMany([{ name: "Jane", age: 25, city: "Paris" }, { name: "Mike", age: 28, city: "London" }])
查询文档
  • 查找所有文档db.<collection>.find()会返回集合中的所有文档。

  • 条件查询:你可以传递一个查询文档来指定查询条件,例如查找所有年龄大于25的文档:

    db.myCollection.find({ age: { $gt: 25 } })
  • 限制返回字段:使用第二个参数来限制返回的字段,例如只返回namecity字段:

    db.myCollection.find({}, { name: 1, city: 1 })
更新文档
  • 更新单个文档db.<collection>.updateOne(filter, update, options)命令用于更新一个符合条件的文档。例如,更新第一个名字为"John"的文档:

    db.myCollection.updateOne({ name: "John" }, { $set: { age: 31 } })
  • 更新多个文档:使用db.<collection>.updateMany(filter, update, options)命令可以更新所有符合条件的文档。例如,将所有位于"New York"的文档的city字段更新为"Brooklyn":

    db.myCollection.updateMany({ city: "New York" }, { $set: { city: "Brooklyn" } })
删除文档
  • 删除单个文档db.<collection>.deleteOne(filter)命令删除第一个符合条件的文档。
  • 删除多个文档db.<collection>.deleteMany(filter)命令删除所有符合条件的文档。

6. 高级查询

        MongoDB提供了强大的查询能力,可以使用各种操作符来执行复杂的查询,包括比较、逻辑、数组等操作符。

比较操作符

        比较操作符允许进行数值比较,常用的包括$gt (大于)、$lt (小于)、$gte (大于等于)、$lte (小于等于) 等。例如,查询年龄在25到30岁之间的文档:

db.myCollection.find({ age: { $gte: 25, $lte: 30 } })
逻辑操作符

        逻辑操作符用于组合多个查询条件,常见的逻辑操作符有$and$or$not$nor。例如,查询年龄大于30或住在"New York"的文档:

db.myCollection.find({ $or: [{ age: { $gt: 30 } }, { city: "New York" }] })
数组操作符

        数组操作符可以查询数组类型的字段,如$in$all等。例如,查询拥有"reading"和"traveling"爱好的文档:

db.myCollection.find({ hobbies: { $all: ["reading", "traveling"] } })

7. 索引管理

索引对于提高MongoDB的查询性能至关重要。正确使用索引可以大幅度提高数据检索的速度。

创建索引

        使用db.<collection>.createIndex(keys, options)命令创建索引,其中keys指定了索引字段和索引类型(如升序1或降序-1),options可以指定索引的额外属性。例如,为myCollectioncity字段创建一个升序索引:

db.myCollection.createIndex({ city: 1 })
管理和优化索引

        你可以使用db.<collection>.getIndexes()查看集合的所有索引,使用db.<collection>.dropIndex(index)删除无用或过时的索引。正确管理索引对维护查询性能和存储效率非常重要。

8. 聚合与分析

        聚合操作允许对数据集进行复杂的转换和计算,MongoDB的聚合框架提供了强大的数据处理能力。

聚合操作简介

        聚合操作通常涉及多个阶段,每个阶段对数据进行转换,如过滤、分组、排序等。使用db.<collection>.aggregate([pipeline])进行聚合查询,其中pipeline是一个包含各个阶段的数组。

聚合管道

        聚合管道的常见操作包括$match(过滤文档)、$group(按某些字段分组)、$sort(排序)、$limit(限制结果数量)等。例如,下面的聚合查询按城市分组,计算每个城市的平均年龄:

db.myCollection.aggregate([ { $group: { _id: "$city", averageAge: { $avg: "$age" } } }, { $sort: { averageAge: -1 } } ])

9. 备份与恢复

在数据库管理中,定期备份数据是非常重要的,以确保数据的安全和可恢复性。

备份数据的重要性

定期备份可以保护数据免受硬件故障、数据损坏、操作错误等风险的影响。

使用mongodump和mongorestore
  • mongodump:这是MongoDB提供的一个备份工具,可以导出所有数据库数据到BSON文件中。使用方法如下:

    mongodump --db <database_name> --out <backup_directory>

    这会将指定数据库的备份保存在指定的目录中。

  • mongorestore:与mongodump相对应,这个工具用于恢复由mongodump导出的数据。使用方法如下:

    mongorestore --db <database_name> <backup_directory>

    这会从指定目录中的备份文件恢复数据库。

10. 数据导入导出

MongoDB提供了工具来帮助用户导入和导出数据,这对于数据迁移和备份非常有用。

使用mongoimport和mongoexport
  • mongoimport:这个工具用于将JSON、CSV或TSV格式的数据导入到MongoDB集合中。例如,导入JSON文件到指定集合:

    mongoimport --db <database_name> --collection <collection_name> --file <file_name>.json
  • mongoexport:与mongoimport相对应,这个工具用于将数据从MongoDB集合导出到JSON或CSV格式的文件中。例如,导出集合数据到JSON文件:

mongoexport --db <database_name> --collection <collection_name> --out <output_file_name>.json

11. 安全与权限管理

        在公开或敏感的应用环境中,确保数据库的安全是非常重要的。

配置访问控制

        启用访问控制来限制对MongoDB数据的访问。通过创建用户账号和角色,为每个用户分配适当的权限。

用户和角色管理
  • 创建用户:可以使用db.createUser()命令创建新用户,并为其指定角色。例如:

db.createUser({user: "myUser",pwd: "myPassword",roles: [ { role: "readWrite", db: "myDatabase" } ]
})

MongoDB常用命令大全

# 显示所有数据库
show dbs# 切换到指定数据库(不存在则创建)
use <database_name># 显示当前数据库中的所有集合
show collections# 删除当前数据库
db.dropDatabase()# 创建集合
db.createCollection("<collection_name>", options)# 删除集合
db.<collection_name>.drop()# 插入单个文档
db.<collection_name>.insertOne({<document>})# 插入多个文档
db.<collection_name>.insertMany([{<document1>}, {<document2>}, ...])# 查询所有文档
db.<collection_name>.find()# 查询符合条件的文档
db.<collection_name>.find({<query>})# 更新符合条件的第一个文档
db.<collection_name>.updateOne({<query>}, {$set: {<update>}})# 更新所有符合条件的文档
db.<collection_name>.updateMany({<query>}, {$set: {<update>}})# 替换一个文档
db.<collection_name>.replaceOne({<query>}, {<newDocument>})# 删除符合条件的第一个文档
db.<collection_name>.deleteOne({<query>})# 删除所有符合条件的文档
db.<collection_name>.deleteMany({<query>})# 创建索引
db.<collection_name>.createIndex({<field>: <direction>})# 列出所有索引
db.<collection_name>.getIndexes()# 删除索引
db.<collection_name>.dropIndex("<index_name>")# 执行聚合管道
db.<collection_name>.aggregate([{<stage1>}, {<stage2>}, ...])# 备份数据库
mongodump --db <database_name> --out <destination_directory># 恢复数据库
mongorestore --db <database_name> <path_to_backup># 导入数据
mongoimport --db <database_name> --collection <collection_name> --file <input_file># 导出数据
mongoexport --db <database_name> --collection <collection_name> --out <output_file># 创建用户
db.createUser({user: "<username>", pwd: "<password>", roles: [{role: "<role>", db: "<database_name>"}]})# 删除用户
db.dropUser("<username>")# 更新用户权限
db.updateUser("<username>", {roles: [{role: "<new_role>", db: "<database_name>"}]})# 查看服务器状态
db.serverStatus()# 查看当前操作
db.currentOp()# 杀掉指定操作
db.killOp(<opid>)# 数据库修复和压缩
db.repairDatabase()# 查看集合的统计信息
db.<collection_name>.stats()# 重命名集合
db.<collection_name>.renameCollection("<new_collection_name>")# 限制查询结果数量
db.<collection_name>.find().limit(<number>)# 跳过指定数量的文档
db.<collection_name>.find().skip(<number>)# 对查询结果排序
db.<collection_name>.find().sort({<field>: <direction>})
查询操作
// 查询集合中的所有文档
db.<collection>.find()// 查询符合条件的文档
db.<collection>.find({<field>: <value>})// 使用比较操作符进行查询(例如:$gt, $lt, $eq, $ne等)
db.<collection>.find({<field>: {$gt: <value>}})// 查询指定字段包含某个值的文档(数组字段)
db.<collection>.find({<arrayField>: <value>})// 查询指定字段包含数组中所有值的文档
db.<collection>.find({<arrayField>: {$all: [<value1>, <value2>, ...]}})// 使用逻辑操作符进行查询($and, $or, $not, $nor)
db.<collection>.find({$or: [{<field1>: <value1>}, {<field2>: <value2>}]})// 使用$in操作符查询字段值在指定数组内的文档
db.<collection>.find({<field>: {$in: [<value1>, <value2>, ...]}})// 查询文档中存在指定字段的文档
db.<collection>.find({<field>: {$exists: true}})// 使用正则表达式进行查询
db.<collection>.find({<field>: {$regex: <pattern>}})// 限制查询结果数量
db.<collection>.find().limit(<number>)// 跳过指定数量的查询结果
db.<collection>.find().skip(<number>)// 对查询结果进行排序(1为升序,-1为降序)
db.<collection>.find().sort({<field>: 1})// 计算符合查询条件的文档数量
db.<collection>.find({<condition>}).count()// 在查询中使用投影,限制返回的字段
db.<collection>.find({<condition>}, {<field1>: 1, <field2>: 1})// 使用聚合管道进行复杂查询
db.<collection>.aggregate([{ $match: {<condition>} },{ $group: {_id: "$<field>", count: {$sum: 1}} },{ $sort: {count: -1} }
])// 使用$lookup进行集合间的连接查询
db.<collection>.aggregate([{ $lookup: {from: "<otherCollection>",localField: "<localField>",foreignField: "<foreignField>",as: "<outputArrayField>"} }
])

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/751076.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Win10 无法安装微软1月安全更新,出现 0x80070643 错误

出现这个问题的原因在于系统分配的“恢复分区”空间不足&#xff0c;该更新在安装时会失败。大致的思路是利用dispart工具收缩C盘空间&#xff0c;扩展该分区的空间。本人开始的“恢复分区”的空间是603MB&#xff0c;安装更新失败&#xff0c;扩充了250MB后&#xff0c;成功了…

基于springboot+mybatis调用MySQL存储过程

前言&#xff1a; 很多公司一般不使用JAVA写存储过程&#xff0c;因为写法较为复杂&#xff0c;不方便后期维护。 不排除一些公司项目会使用。 如果索引优化已经达到很好的性能&#xff0c;不建议使用。以下示例供学习参考&#xff1a; demo源码&#xff1a;https://gitee.com…

一文彻底搞懂进程间通信方式

文章目录 1. 进程间通信的概念2. 进程间通信的7种方式2.1 管道/匿名管道(pipe)2.2 有名管道(FIFO)2.3 信号(Signal)2.4 消息(Message)队列2.5 共享内存(share memory)2.6 信号量(semaphore)2.7 套接字(socket) 1. 进程间通信的概念 每个进程各自有不同的用户地址空间&#xff…

由浅到深认识C语言(14):枚举

该文章Github地址&#xff1a;https://github.com/AntonyCheng/c-notes 在此介绍一下作者开源的SpringBoot项目初始化模板&#xff08;Github仓库地址&#xff1a;https://github.com/AntonyCheng/spring-boot-init-template & CSDN文章地址&#xff1a;https://blog.csdn…

操作系统系列学习——进程同步与信号量

文章目录 前言进程同步与信号量 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划学习操作系统并完成6.0S81&#xff0c;加油&#xff01; 本文总结自B站【哈工大】操作系统 李治军&#xff08;全32讲&#xff09; 老师课程讲的非常好&#xff0c;感谢 【哈…

存内领域前沿,基于忆阻器的存内计算----浅析忆阻存内计算

目录 一.概念浅析 1.存内计算 2.忆阻器 3.基于忆阻器的存内计算 二.忆阻器的分类 1.磁效应忆阻器 2 .相变效应忆阻器 3 .阻变效应忆阻器 三.基于忆阻器的存内计算原理 1. 利用二值忆阻器的布尔计算 3.1R-R 逻辑运算 3.2V-R 逻辑运算 3.3V-V 逻辑运算 2. 利用模拟…

GPU密集型计算性能优化的方法和技术

对GPU密集型计算进行性能优化的方法和技术多种多样。通过一些优化策略和技术需要综合考虑应用程序的具体需求、所使用的GPU硬件、以及编程模型和库的选择。通过不断地分析和调整&#xff0c;可以实现GPU计算性能的持续提升。以下是一些常用的优化策略和技术&#xff1a; 算法优…

Nacos注册中心与配置管理

Nacos注册中心与配置管理 1 Nacos注册中心1.1.认识Nacos1.2.服务注册到nacos1.3.服务分级存储模型1.4.权重配置1.5.环境隔离1.6.Nacos与Eureka的区别 2 CAP3.Nacos配置管理3.1.统一配置管理3.2.bootstrap了解3.3.配置热更新3.4.配置共享 1 Nacos注册中心 1.1.认识Nacos 国内公…

main方法语法

main方法语法 深入理解main方法main特别说明在idea中main动态传值 深入理解main方法 解释 main 方法的形式&#xff1a;public static void main&#xff08;String[ ] args&#xff09;{ } 1) main 方法时虚拟机调用&#xff1b; 2) java虚拟机需要调用类的 main() 方法&…

免费开源:自动会议记录接口调用|语音识别接口|语音识别API

一、开源项目介绍 一款多模态AI能力引擎&#xff0c;专注于提供自然语言处理&#xff08;NLP&#xff09;、情感分析、实体识别、图像识别与分类、OCR识别和语音识别等接口服务。该平台功能强大&#xff0c;支持本地化部署&#xff0c;并鼓励用户体验和开发者共同完善&#xf…

【Linux】进程间通信2(共享内存||消息队列)

共享内存 介绍 1.共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间&#xff0c;这些进程间数据传递不再涉及到内核&#xff0c;换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据。 2.当共享内存创建出来后&#xff0c;通过系统调用挂接到…

Java实现简单的通讯录

每日一言 泪眼问花花不语&#xff0c;乱红飞过秋千去。 —欧阳修- 简单的通讯录实现&#xff0c;跟写Java实现图书管理系统差不多&#xff0c;用到的知识也差不多&#xff0c;就当个小练习&#xff0c;练习一下写Java程序的手感。 Java实现图书管理系统 关于通讯录的代码都写…

Visio 去掉图形四周的空白区域(页边距)

1&#xff0c;打开自定义功能区 [文件]->[选项]->[自定义功能区] 2,打开设置页边距设置界面 点击之后再上方输入框进行修改&#xff0c;点击对钩进行确认修改&#xff0c;修改PageLeftMargin、PageRightMargin、PageTopMargin和PageBottomMargin这四个参数。

简历信息泄露?如何用图数据库技术解决简历泄露事件的反欺诈挑战

“金三银四”&#xff0c;又到了春招黄金期&#xff0c;但个人简历泄露的数据安全问题诸见报端&#xff0c;甚至在此前的3.15晚会报道中就揭露过招聘平台上的简历信息被泄露&#xff0c;不法分子通过各种渠道获取到简历&#xff0c;并用于欺诈活动&#xff0c;形成了一套庞大的…

wifi的5G和3GPP的5G

wifi 5G 跑的是802.11的协议。 wifi的5G指的就是频率&#xff0c;例如wifi2.4G&#xff0c;其频段处于2.400GHz~2.4835GHz之间&#xff0c;wifi5G的频率范围为5.15GHz到5.875GHz&#xff0c;其中包括多个频道。 这里有个误区&#xff0c;并不是运行在5GHz频段的WI-FI就是5G …

java过滤器Filter相关知识点汇总

1.Filter概述 Servlet Filter又称Servlet过滤器&#xff0c;它是在Servlet2.3规范中定义的&#xff0c;能够对Servlet容器传给Web资源的request对象和response对象执行检查和修改。 Filter不是Servlet&#xff0c;不能直接访问&#xff0c;其本身也不能生成request对象和resp…

很好的一本书,推荐给你们《Hello 算法》

算法犹如美妙的交响乐&#xff0c;每一行代码都像韵律般流淌。 愿这本书在你的脑海中轻轻响起&#xff0c;留下独特而深刻的旋律。 本项目旨在打造一本开源免费、新手友好的数据结构与算法入门教程。 全书采用动画图解&#xff0c;内容清晰易懂、学习曲线平滑&#xff0c;引导…

子组件自定义事件$emit实现新页面弹窗关闭之后父界面刷新

文章目录 需求弹窗关闭之后父界面刷新展示最新数据 实现方案AVUE 大文本默认展开slotVUE 自定义事件实现 父界面刷新那么如何用呢? 思路核心代码1. 事件定义2. 帕斯卡命名组件且在父组件中引入以及注册3. 子组件被引用与父事件监听4.父组件回调函数 5.按钮弹窗事件 需求 弹窗…

HCIP—OSPF虚链路实验

OSPF虚链路—Vlink 作用&#xff1a;专门解决OSPF不规则区域所诞生的技术&#xff0c;是一种虚拟的&#xff0c;逻辑的链路。实现非骨干区域和骨干区域在逻辑上直接连接。注意虚链路条件&#xff1a;只能穿越一个区域&#xff0c;通常对虚链路进行认证功能的配置。虚链路认证也…

【渗透测试】redis漏洞利用

redis安装及配置 wget http://download.redis.io/releases/redis-3.2.0.tar.gz tar xzf redis-3.2.0.tar.gz cd redis-3.2.0 make cp /root/redis-6.2.6/redis.conf /usr/local/redis/bin/ cd /usr/local/redis/bin/ vi redis.conf #修改内容如下&#xff1a; #protected-mode …