MongoDB从零基础搭建到实战
MongoDB从零基础搭建到实战MongoDB作为当下最流行的开源文档型NoSQL数据库凭借灵活的文档结构、高扩展性和易用性成为前后端开发、大数据存储、云原生项目的首选数据库之一。相比传统关系型数据库它无需严格预定义表结构适配多变的业务数据需求尤其适合Node.js、Python、Java等主流开发场景。本篇教程将从零开始带你完成MongoDB的环境搭建、基础配置、核心命令操作、可视化工具使用、高级查询与实战全程步骤详细、代码可直接复用适合零基础新手入门也适合有基础的开发者查漏补缺。一、MongoDB核心概念先理清学习MongoDB前先搞懂核心术语避免和关系型数据库混淆上手更快。1.1 MongoDB与关系型数据库核心对比MongoDB术语关系型数据库MySQL/Oracle术语说明数据库Database数据库Database存储数据的容器一个MongoDB可建多个库集合Collection数据表Table无需预定义结构存储同类文档动态扩容文档Document数据行Row最小数据单元用BSON格式类JSON支持更多数据类型字段Field数据列Column文档中的键值对支持嵌套、数组结构_id主键Primary KeyMongoDB自动生成唯一主键也可自定义1.2 核心特性文档型存储数据以BSON格式存储支持嵌套对象、数组无需严格Schema高可用支持副本集主节点故障自动切换保证数据不丢失高扩展性支持分片集群应对海量数据和高并发场景丰富查询支持条件查询、聚合、索引、排序、分页媲美关系型数据库跨平台支持Windows、Mac、Linux全系统兼容主流开发语言二、MongoDB环境搭建全系统教程MongoDB分为**社区版Community**和企业版个人学习和中小型项目使用社区版完全足够本篇以最新稳定版MongoDB 7.0为例讲解。2.1 系统环境要求WindowsWindows 10 及以上版本MacmacOS 10.15 及以上版本LinuxUbuntu 18.04/CentOS 7/Debian 10内存建议至少2GB开发环境1GB也可运行2.2 Windows系统安装与配置2.2.1 下载安装包访问MongoDB官方下载地址https://www.mongodb.com/try/download/community选择Version7.0最新稳定版PlatformWindowsPackageMSI点击Download下载安装包双击运行2.2.2 安装步骤同意协议选择Complete完整安装新手推荐服务配置页面勾选“Install MongoD as a Service”设置服务自动启动数据目录默认C:\Program Files\MongoDB\Server\7.0\data日志目录默认C:\Program Files\MongoDB\Server\7.0\log无需修改取消勾选“Install MongoDB Compass”后续单独安装可视化工具点击Install完成安装2.2.3 配置环境变量关键右键此电脑→属性→高级系统设置→环境变量在系统变量中找到Path点击编辑→新建添加MongoDB的bin目录路径C:\Program Files\MongoDB\Server\7.0\bin一路确定保存打开命令提示符CMD输入mongod --version显示版本号即配置成功2.2.4 启动与关闭服务启动服务管理员CMD输入net start MongoDB关闭服务管理员CMD输入net stop MongoDB连接数据库CMD输入mongosh进入MongoDB命令行客户端2.3 Mac系统安装与配置2.3.1 Homebrew安装推荐打开终端安装MongoDB官方tapbrew tap mongodb/brew安装社区版brew install mongodb-community7.02.3.2 启动服务开机自启brew services start mongodb-community7.0临时启动mongod --config /opt/homebrew/etc/mongod.conf连接数据库终端输入mongosh2.4 LinuxUbuntu系统安装与配置导入公钥wget -qO - https://www.mongodb.org/static/pgp/server-7.0.asc | sudo apt-key add -添加软件源echo deb [ archamd64,arm64 ] https://repo.mongodb.org/apt/ubuntu jammy/mongodb-org/7.0 multiverse | sudo tee /etc/apt/sources.list.d/mongodb-org-7.0.list更新源并安装sudo apt-get update sudo apt-get install -y mongodb-org启动服务sudo systemctl start mongod设置开机自启sudo systemctl enable mongod连接数据库mongosh2.5 验证安装成功任意系统终端输入mongosh出现以下提示即连接成功Current Mongosh Log ID: xxxxxxxx Connecting to: mongodb://127.0.0.1:27017/ Using MongoDB:7.0.0 Using Mongosh:2.0.0 test默认连接端口27017默认数据库test三、MongoDB基础核心操作mongosh命令行进入mongosh客户端后即可执行数据库、集合、文档的增删改查操作所有命令区分大小写以下为高频常用命令建议收藏。3.1 数据库操作3.1.1 查看所有数据库show dbs # 或 show databases注意空数据库不会显示插入数据后才会展示3.1.2 创建/切换数据库# 语法use 数据库名 use mydb # 切换到mydb库不存在则自动创建3.1.3 查看当前所在数据库db3.1.4 删除数据库# 先切换到要删除的库 use mydb # 执行删除 db.dropDatabase()3.2 集合操作相当于数据表3.2.1 创建集合MongoDB无需手动创建集合插入文档时自动创建也可手动创建指定配置# 手动创建集合 db.createCollection(user)# 创建固定大小集合可选 db.createCollection(log,{capped:true,size:1024*1024,max:1000})3.2.2 查看所有集合show collections # 或 show tables3.2.3 删除集合# 语法db.集合名.drop()db.user.drop()3.3 文档操作核心增删改查文档是MongoDB的核心以键值对形式存储支持嵌套、数组以下用user集合演示。3.3.1 插入文档插入单个文档db.user.insertOne({name:张三,age:22,gender:男,hobby:[编程,篮球],address:{city:北京,district:朝阳区},createTime:newDate()})插入多个文档db.user.insertMany([{name:李四,age:25,gender:女,hobby:[读书,旅游]},{name:王五,age:19,gender:男,hobby:[游戏,摄影]},{name:赵六,age:28,gender:女,hobby:[健身,美食]}])3.3.2 查询文档查询所有文档格式化输出db.user.find().pretty()条件查询#1.精确查询查找姓名为张三的用户 db.user.find({name:张三}).pretty()#2.比较查询年龄大于20的用户($gt大于,$lt小于,$gte大于等于,$lte小于等于,$ne不等于)db.user.find({age:{$gt:20}}).pretty()#3.多条件且查询年龄20-30之间的男性用户 db.user.find({age:{$gte:20,$lte:30},gender:男}).pretty()#4.或查询男性或年龄大于25db.user.find({$or:[{gender:男},{age:{$gt:25}}]}).pretty()#5.模糊查询姓名包含三db.user.find({name:/三/}).pretty()#6.字段过滤只显示name和age隐藏_id db.user.find({},{name:1,age:1,_id:0}).pretty()排序、分页、统计# 排序按年龄升序1升序-1降序 db.user.find().sort({age:1}).pretty()# 分页跳过2条取2条skip跳过条数limit取条数 db.user.find().skip(2).limit(2).pretty()# 统计总数 db.user.countDocuments()# 条件统计 db.user.countDocuments({gender:男})3.3.3 更新文档更新单个文档# 将张三的年龄改为23db.user.updateOne({name:张三},# 查询条件{$set:{age:23}}# 更新内容)更新多个文档# 所有女性用户添加status字段 db.user.updateMany({gender:女},{$set:{status:active}})替换整个文档db.user.replaceOne({name:王五},{name:王五,age:20,gender:男,hobby:[阅读]})3.3.4 删除文档# 删除单个文档删除赵六 db.user.deleteOne({name:赵六})# 删除多个文档删除年龄小于20的用户 db.user.deleteMany({age:{$lt:20}})# 清空集合所有文档保留集合 db.user.deleteMany({})四、MongoDB可视化工具使用MongoDB Compass命令行操作适合熟练开发者新手推荐使用MongoDB Compass官方免费可视化工具图形化界面操作无需记命令直观管理数据库。4.1 安装与连接下载地址https://www.mongodb.com/products/compass安装后打开默认连接地址mongodb://localhost:27017点击Connect即可连接本地MongoDB服务4.2 核心功能可视化查看所有数据库、集合、文档图形化新增、编辑、删除文档可视化创建索引、执行查询语句查看数据库性能、数据统计导入导出数据支持JSON、CSV格式五、MongoDB高级操作5.1 索引管理提升查询效率索引是MongoDB性能优化的核心避免全表扫描常用索引操作# 创建单字段索引 db.user.createIndex({name:1})# 创建复合索引 db.user.createIndex({age:1,name:-1})# 查看所有索引 db.user.getIndexes()# 删除索引 db.user.dropIndex(name_1)5.2 聚合查询Aggregation适合复杂数据统计、分组、计算类似SQL的GROUP BY# 按性别分组统计每组人数和平均年龄 db.user.aggregate([{$group:{_id:$gender,count:{$sum:1},avgAge:{$avg:$age}}}])5.3 数据备份与恢复5.3.1 备份数据mongodump# 备份所有数据库mongodump# 备份指定数据库mongodump-dmydb-o./backup5.3.2 恢复数据mongorestore# 恢复所有数据库mongorestore# 恢复指定数据库mongorestore-dmydb ./backup/mydb六、常见问题与避坑指南mongosh无法连接检查MongoDB服务是否启动端口27017是否被占用插入数据后数据库不显示空数据库不展示插入集合数据后自动显示查询速度慢未创建索引对高频查询字段建立索引权限问题生产环境务必设置账号密码禁止外网直接访问27017端口数据丢失重要数据定期备份生产环境建议搭建副本集保证高可用七、总结本篇教程完整覆盖了MongoDB从环境搭建、基础命令、可视化操作到高级实战的全流程MongoDB的灵活文档结构和易用性让它成为现代开发的必备数据库。零基础新手按照步骤一步步操作即可快速上手进阶开发者可重点掌握索引优化、聚合查询、副本集搭建等内容适配生产环境需求。后续可深入学习MongoDB集群部署、事务操作、与主流编程语言Node.js/Python/Java集成等内容进一步提升开发和运维能力。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2458574.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!