MongoDB 学习指南:深入探索非关系型数据库


MongoDB学习资料

MongoDB学习资料

MongoDB学习资料


在当今数字化时代,数据量呈爆炸式增长,数据结构也变得愈发复杂多样。传统的关系型数据库在处理一些大规模、高并发以及非结构化数据时,逐渐显露出局限性。而 MongoDB 作为一款领先的非关系型数据库,凭借其灵活的数据模型、出色的扩展性和强大的性能,迅速在众多领域得到广泛应用。无论是新兴的互联网企业,还是传统的金融、医疗等行业,都能看到 MongoDB 的身影。接下来,让我们一同开启 MongoDB 的学习之旅。

一、MongoDB 初相识:基础概念与环境搭建

认识 MongoDB:

MongoDB 是基于分布式文件存储的非关系型数据库,采用了一种独特的文档型数据模型。与关系型数据库以表格形式存储数据不同,MongoDB 将数据存储为 BSON(Binary JSON)格式的文档,这种文档类似于 JSON 对象,但在存储和处理上更加高效。例如,一个用户文档可以表示为:

{"name": "John Doe","age": 30,"email": "johndoe@example.com","address": {"street": "123 Main St","city": "Anytown","state": "CA","zip": "12345"}
}

这种灵活的数据模型使得 MongoDB 能够轻松应对各种复杂的数据结构,无需像关系型数据库那样进行繁琐的表结构设计和范式化处理。

环境搭建:

下载安装:首先,前往 MongoDB 官方网站(https://www.mongodb.com/try/download/community),根据你的操作系统版本下载对应的安装包。对于 Windows 用户,下载完成后,运行安装程序,按照向导逐步完成安装。在安装过程中,注意选择合适的安装路径和配置选项,例如是否将 MongoDB 安装为系统服务等。对于 Linux 和 macOS 用户,可以通过包管理器进行安装,例如在 Ubuntu 系统中,可以使用以下命令进行安装:

sudo apt-get update
sudo apt-get install -y mongodb - community

启动服务:安装完成后,需要启动 MongoDB 服务。在 Windows 系统中,可以通过服务管理器找到 “MongoDB” 服务并启动它。在 Linux 和 macOS 系统中,可以使用以下命令启动服务:

sudo systemctl start mongod

连接数据库:MongoDB 提供了一个名为 “mongo” 的交互式 shell,用于与数据库进行交互。在命令行中输入 “mongo”,即可连接到本地的 MongoDB 实例。连接成功后,你将看到 MongoDB 的命令行提示符,此时就可以开始执行各种 MongoDB 命令了。

二、深入 MongoDB 核心:数据操作与管理

数据库与集合操作:

创建与选择数据库:在 MongoDB 中,可以使用 “use” 命令来创建或选择一个数据库。例如,要创建一个名为 “myDB” 的数据库(如果该数据库不存在,MongoDB 会在首次插入数据时自动创建它),并切换到该数据库,可以执行以下命令:

use myDB

创建与管理集合:集合类似于关系型数据库中的表,用于存储文档。使用 “db.createCollection ()” 方法可以创建一个集合。例如,要创建一个名为 “users” 的集合,可以执行以下命令:

db.createCollection("users")

创建集合后,可以使用 “db.collectionName” 来引用该集合,例如 “db.users”。同时,还可以对集合进行重命名、删除等操作,例如使用 “db.users.renameCollection (‘newUsers’)” 对集合进行重命名,使用 “db.users.drop ()” 删除集合。

文档操作:

插入文档:使用 “insertOne ()” 方法可以向集合中插入一个文档,使用 “insertMany ()” 方法可以插入多个文档。例如,要向 “users” 集合中插入一个用户文档,可以执行以下命令:

db.users.insertOne({"name": "Alice","age": 25,"email": "alice@example.com"
})

要插入多个用户文档,可以执行以下命令:

db.users.insertMany([{"name": "Bob","age": 35,"email": "bob@example.com"},{"name": "Charlie","age": 40,"email": "charlie@example.com"}
])

查询文档:查询是数据库操作中最常用的功能之一。MongoDB 提供了强大的查询功能,使用 “find ()” 方法可以查询集合中的文档。例如,要查询 “users” 集合中的所有文档,可以执行以下命令:

db.users.find()

要查询年龄大于 30 岁的用户文档,可以执行以下命令:

db.users.find({ "age": { "$gt": 30 } })

这里的 “ lt”(小于)、“ in”(在某个集合中)等,以满足各种复杂的查询需求。

更新文档:使用 “updateOne ()” 方法可以更新一个文档,使用 “updateMany ()” 方法可以更新多个文档。例如,要将 “users” 集合中名字为 “Alice” 的用户的年龄更新为 26 岁,可以执行以下命令:

db.users.updateOne({ "name": "Alice" }, { "$set": { "age": 26 } })

这里的 “$set” 操作符用于指定要更新的字段和值。

删除文档:使用 “deleteOne ()” 方法可以删除一个文档,使用 “deleteMany ()” 方法可以删除多个文档。例如,要删除 “users” 集合中年龄大于 40 岁的所有用户文档,可以执行以下命令:
db.users.deleteMany({ “age”: { “$gt”: 40 } })

三、MongoDB 进阶之路:索引、聚合与复制集

索引优化:

索引可以显著提高数据库的查询性能。在 MongoDB 中,可以使用 “createIndex ()” 方法为集合创建索引。例如,要为 “users” 集合的 “email” 字段创建一个单字段索引,可以执行以下命令:

db.users.createIndex({ "email": 1 })

这里的 “1” 表示升序索引,如果要创建降序索引,可以使用 “-1”。除了单字段索引,MongoDB 还支持复合索引、多键索引等多种类型的索引,以满足不同的查询需求。在创建索引时,需要根据实际的查询场景进行合理设计,避免创建过多不必要的索引,以免影响写入性能。

聚合框架:

聚合框架是 MongoDB 的一个强大功能,它允许对文档进行复杂的数据处理和分析。使用聚合框架,可以进行数据分组、统计、连接等操作。聚合操作使用 “aggregate ()” 方法,通过一系列的管道操作符来实现。例如,要统计 “users” 集合中每个年龄段的用户数量,可以执行以下聚合操作:

db.users.aggregate([{"$group": {"_id": "$age","count": { "$sum": 1 }}}
])

这里的 “ sum” 操作符统计每个组中的文档数量。

复制集:

复制集是 MongoDB 实现高可用性和数据冗余的重要机制。它由一组 MongoDB 实例组成,其中一个为主节点,其他为从节点。主节点负责处理所有的写入操作,并将写入操作的日志同步到从节点。从节点可以用于读取操作,从而分担主节点的负载。要创建一个复制集,首先需要在多个节点上启动 MongoDB 实例,并配置它们为复制集的成员。然后,在其中一个节点上使用 “rs.initiate ()” 命令初始化复制集。例如,以下是一个简单的复制集配置示例:

rs.initiate({_id: "myReplSet",members: [{ _id: 0, host: "localhost:27017" },{ _id: 1, host: "localhost:27018" },{ _id: 2, host: "localhost:27019" }]
})

这里的 “_id” 指定复制集的名称,“members” 数组中列出了复制集的成员节点。

四、MongoDB 实战应用:项目中的最佳实践

数据建模:

在实际项目中,合理的数据建模是关键。根据业务需求和数据特点,设计出灵活、高效的数据结构。例如,在一个电商项目中,对于商品数据,可以将商品的基本信息、库存信息、评论信息等存储在一个文档中,利用 MongoDB 的嵌套文档和数组功能,避免数据的冗余和复杂的关联查询。同时,要考虑数据的扩展性,以便在业务发展过程中能够轻松地添加新的字段和功能。

性能优化:

除了创建合适的索引外,还可以通过优化查询语句、调整服务器配置等方式来提高 MongoDB 的性能。在编写查询语句时,尽量使用覆盖索引,减少数据的扫描范围。同时,合理设置 MongoDB 的缓存大小、线程池大小等参数,以充分利用服务器资源。此外,定期对数据库进行碎片整理和性能监控,及时发现并解决性能问题。

数据安全:

确保数据的安全性至关重要。在 MongoDB 中,可以通过启用身份验证、设置访问控制列表(ACL)等方式来保护数据库。启用身份验证后,用户需要提供用户名和密码才能连接到数据库。同时,可以为不同的用户分配不同的权限,例如只读权限、读写权限等,以限制用户对数据库的操作。此外,定期进行数据备份,并将备份数据存储在安全的位置,以防止数据丢失。

MongoDB 的学习是一个不断深入和实践的过程。通过掌握上述基础知识和高级特性,并将其应用到实际项目中,你将能够充分发挥 MongoDB 的优势,为企业的数据管理和业务发展提供有力支持。随着对 MongoDB 的不断探索,你会发现它在处理各种复杂数据场景时的强大能力和灵活性,为你在数据库领域的发展开辟广阔的道路。

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

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

相关文章

学习微信小程序的下拉列表控件-picker

1、创建一个空白工程 2、index.wxml中写上picker布局&#xff1a; <!--index.wxml--> <view class"container"><picker mode"selector" range"{{array}}" bindchange"bindPickerChange"><view class"pick…

【神经网络基础】

目录 一、神经网络的构成 1.1什么是神经网络&#xff1f; 1.2 激活函数 1.2.1 Sigmoid 1.2.2 Tanh 1.2.3 ReLU 1.2.4 softmax 1.2.5 其他激活函数 1.2.6 选择激活函数 1.3 参数初始化 1.4 模型构建 二、损失函数 2.1 分类问题 2.1.1多分类&#xff08;多分类交叉…

STM32 学习笔记【补充】(十)硬件I2C读写MPU6050

该系列为笔者在学习STM32过程&#xff08;主线是江科大的视频&#xff09;中的记录与发散思考。 初学难免有所纰漏、错误&#xff0c;还望大家不吝指正&#xff0c;感谢~ 一、I2C 外设简介 I2C&#xff08;Inter-Integrated Circuit&#xff09;是一种多主多从的串行通信协议…

.Net Core webapi 实现JWT认证

文章目录 需求准备创建JWT配置创建JWTService注册JWT创建中间件读取jwt的token在需要的接口上添加属性启动认证启动swagger的授权认证使用 需求 实现一个记录某个用户所有操作的功能 准备 创建你的webapi项目从nuget下载安装JWT资源包根据你的项目使用.net版本下载对应的jwt…

leetcode203-移除链表元素

leetcode203 什么是链表 之前不懂链表的数据结构&#xff0c;一看到链表的题目就看不明白 链表是通过next指针来将每个节点连接起来的&#xff0c;题目中给的链表是单向链表&#xff0c;有两个值&#xff0c;一个val表示值&#xff0c;一个next&#xff1a;表示连接的下一个…

在21世纪的我用C语言探寻世界本质——字符函数和字符串函数(2)

人无完人&#xff0c;持之以恒&#xff0c;方能见真我&#xff01;&#xff01;&#xff01; 共同进步&#xff01;&#xff01; 文章目录 一、strncpy函数的使用二、strncat函数的使用三、strncmp函数的使用四、strstr的使用和模拟实现五、strtok函数的使用六、strerror和pe…

stack_queue的底层,模拟实现,deque和priority_queue详解

文章目录 适配器Stack的模拟实现Queue的模拟实现vector和list的对比dequedeque的框架deque的底层 priority_queuepriority_queue的使用priority_queue的底层仿函数的使用仿函数的作用priority_queue模拟实现 适配器 适配器是一种模式&#xff0c;这种模式将类的接口转化为用户希…

LLM - 大模型 ScallingLaws 的 CLM 和 MLM 中不同系数(PLM) 教程(2)

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/145188660 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 Scalin…

杰盛微 IRS2336STRPBF 700V带使能和故障报告的三相反逻辑驱动芯片 SOP28封装

IRS2336STRPBF 700V带使能和故障报告的三相反逻辑驱动芯片 IRS2336是 N型高压、高速功率 MOSFET/IGBT高低侧三相栅极驱动芯片&#xff0c;包含三路独立的半桥驱动电路。内部集成了欠压保护和过流保护功能&#xff0c;出现异常时立即关断六通道输出。提供外部使能控制可同时关断…

深入理解第三范式(3NF):数据库设计中的重要性与实践

title: 深入理解第三范式(3NF):数据库设计中的重要性与实践 date: 2025/1/17 updated: 2025/1/17 author: cmdragon excerpt: 在数据库设计中,规范化是确保数据完整性、减少冗余和提高查询效率的关键过程。第三范式(3NF)作为关系数据库设计的高级规范,建立在前两范式…

mongoose 支持https踩坑纪实

简述 mongoose是C编写的嵌入式web服务&#xff0c;它能够支持https协议&#xff0c;可以简单的部署&#xff0c;但要做到完美部署&#xff0c;不是那么容易。 部署方法 本人使用的是最新的7.16版&#xff0c;以前版本似乎是要通过修改 头文件中的 MG_ENABLE_SSL 宏定义&…

RK3576 Android14 状态栏和导航栏增加显示控制功能

问题背景&#xff1a; 因为RK3576 Android14用户需要手动控制状态栏和导航栏显示隐藏控制&#xff0c;包括对锁屏后下拉状态栏的屏蔽&#xff0c;在设置功能里增加此功能的控制&#xff0c;故参考一些博客完成此功能&#xff0c;以下是具体代码路径的修改内容。 解决方案&…

C#高级:通过 Assembly 类加载 DLL 和直接引用DLL的方法大全

一、主项目不添加引用 &#xff08;主项目不添加引用&#xff0c;而是通过路径获取指定dll&#xff09; 1.打印类的属性名称 namespace ReflectionDemo {class Program{static void Main(string[] args){// 指定【编译输出】的项目类库dll&#xff08;启动项目编译输出目录下…

【k8s面试题2025】1、练气期

主要通过呼吸吐纳等方法&#xff0c;将外界的天地灵气吸入体内&#xff0c;初步改造身体&#xff0c;使身体素质远超常人。 文章目录 docker 和虚拟机的不同Kubernetes 和 docker 的关系Kube-proxy IPVS 和 iptables 的异同蓝绿发布Kubernetes中常见的数据持久化方式关于 Docke…

音视频入门基础:RTP专题(4)——FFmpeg源码中,判断某文件是否为SDP文件的实现

一、引言 执行《音视频入门基础&#xff1a;RTP专题&#xff08;2&#xff09;——使用FFmpeg命令生成RTP流》中的“媒体文件转推RTP的FFmpeg命令”会生成一个SDP文件&#xff0c;该文件内容如下&#xff1a; v0 o- 0 0 IN IP4 127.0.0.1 sNo Name t0 0 atool:libavformat 61…

【大数据2025】Hadoop 万字讲解

文章目录 一、大数据通识大数据诞生背景与基本概念大数据技术定义与特征大数据生态架构概述数据存储数据计算与易用性框架分布式协调服务和任务调度组件数仓架构流处理架构 二、HDFSHDFS 原理总结一、系统架构二、存储机制三、数据写入流程四、心跳机制与集群管理 安全模式&…

电脑换固态硬盘

参考&#xff1a; https://baijiahao.baidu.com/s?id1724377623311611247 一、根据尺寸和缺口可以分为以下几种&#xff1a; 1、M.2 NVME协议的固态 大部分笔记本是22x42MM和22x80MM nvme固态。 在京东直接搜&#xff1a; M.2 2242 M.2 2280 2、msata接口固态 3、NGFF M.…

回顾2024年在CSDN的成长

文章目录 我与CSDN的初次邂逅初学阶段的阅读CSDN&#xff1a;编程新手的避风港初学者的福音&#xff1a;细致入微的知识讲解考试复习神器&#xff1a;技术总结的“救命指南”曾经的自己&#xff1a;为何迟迟不迈出写博客的第一步兴趣萌芽&#xff1a;从“读”到“想写”的初体验…

抖音ip属地不准是什么原因?可以改吗

在数字化时代&#xff0c;社交媒体平台如抖音已成为人们日常生活的重要组成部分。随着各大平台对用户隐私和数据安全的日益重视&#xff0c;IP属地的显示功能应运而生。然而&#xff0c;不少抖音用户在使用过程中发现&#xff0c;显示的IP属地与实际位置存在偏差&#xff0c;这…

Win11 安装与配置 Java环境 JDK(以JDK11为例)

0&#xff0c;下载JDK 访问JDK官网&#xff1a;Java Downloads | Oracle 选择对应版本进行下载&#xff0c;目前21和23都是可以直接下载的 但是如果需要下载旧版本&#xff0c;往下拉找到要下载的版本&#xff0c;不过这时候下载就需要登录账号了&#xff0c;注册一个就成 2&…