第六课:数据库集成:MongoDB与Mongoose技术应用

本文详细介绍了如何在Node.js应用程序中集成MongoDB数据库,并使用Mongoose库进行数据操作。我们将涵盖MongoDB在Ubuntu 20系统中的安装、Bash命令的CRUD操作、Mongoose数据建模(Schema/Model)、关联查询与聚合管道,以及实战案例——用户注册系统的开发。通过本文,你将掌握Node.js与MongoDB集成的完整流程。

1. MongoDB在Ubuntu 20系统中安装与Bash命令的CRUD操作

1.1 MongoDB安装

在Ubuntu 20系统中安装MongoDB,你可以通过以下步骤进行:

方法一:直接安装

导入公共GPG密钥

wget -qO - https://www.mongodb.org/static/pgp/server-7.0.asc | sudo apt-key add -

创建MongoDB源列表文件

echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/7.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-7.0.list

更新软件包列表并安装MongoDB

sudo apt-get updatesudo apt-get install -y mongodb-org

启动MongoDB服务

sudo systemctl start mongodsudo systemctl enable mongod

方法二:使用Docker镜像

如果你更喜欢使用Docker来管理MongoDB,可以使用以下命令:

docker pull mongodocker run -itd --name mongo_latest -p 27017:27017 mongo

然后,你可以通过docker exec -it mongo_latest mongosh进入MongoDB shell

1.2 Bash命令的CRUD操作

增操作

mongouse myDatabasedb.users.insert({name: "deming_su", age: 22, email: "deming_su@163.com"})

查操作

db.users.find()

更操作

db.users.updateOne({name: "deming_su"}, {$set: {age: 23}})

删操作

db.users.deleteOne({name: "deming_su"})

2. Mongoose数据建模(Schema/Model)

2.1 Mongoose安装

首先,确保你的Node.js环境已经安装完毕,然后通过npm安装Mongoose:

npm install mongoose

2.2 定义Schema

Schema是Mongoose中用于定义文档结构的蓝图。以下是一个简单的用户Schema示例:

const mongoose = require('mongoose');const userSchema = new mongoose.Schema({id: String,name: String,age: Number,email: {type: String,unique: true}
});
2.3 创建Model

Model是Schema的编译版本,用于创建和操作数据库中的文档。你可以使用mongoose.model方法创建Model:

const User = mongoose.model('User', userSchema);
2.4 CRUD操作

使用Mongoose进行CRUD操作非常简单。以下是一些示例:

增操作

const mongoose = require('mongoose');
const User = require('./models/user');mongoose.connect('mongodb://localhost:27017/myDatabase', {useNewUrlParser: true,useUnifiedTopology: true
});const newUser = new User({id: "deming_su", name: "deming_su", age: 28, email: "deming_su@163.com"});newUser.save();

查操作

User.find({id: "deming_su"}, (err, users) => {if (err) {console.error(err);} else {console.log(users);}
});

更操作

User.findByIdAndUpdate('deming_su', {$set: {age: 29}}, (err, user) => {if (err) {console.error(err);} else {console.log(user);}
});

删操作

User.findByIdAndDelete('deming_su', (err, user) => {if (err) {console.error(err);} else {console.log(user);}
});

3. 关联查询与聚合管道

3.1 关联查询

在MongoDB中,关联查询通常通过$lookup操作符在聚合管道中实现。假设我们有两个集合:users和orders,每个订单都属于一个用户,我们可以通过user_id字段进行关联查询。

User.aggregate([{$lookup: {from: 'orders',localField: '_id',foreignField: 'user_id',as: 'orders'}}
]).exec((err, users) => {if (err) {console.error(err);} else {console.log(users);}
});
3.2 聚合管道

聚合管道允许你对集合中的文档进行一系列复杂的转换和聚合操作。以下是一个简单的聚合管道示例,用于统计每个用户的订单总数:

Order.aggregate([{$group: {_id: '$user_id',totalOrders: { $sum: 1 }}}
]).exec((err, results) => {if (err) {console.error(err);} else {console.log(results);}
});

4. 实战:用户注册系统开发

4.1 系统设计

用户注册系统需要实现以下功能:

  • 用户注册:收集用户信息(如用户名、密码、邮箱等)并保存到数据库。
  • 用户登录:验证用户信息并登录系统。
  • 用户注销:清除用户会话并注销系统。
4.2 数据建模

首先,我们需要定义用户数据模型。使用Mongoose,我们可以创建一个简单的用户Schema:

const mongoose = require('mongoose');const userSchema = new mongoose.Schema({username: {type: String,required: true,unique: true},password: {type: String,required: true},email: {type: String,required: true,unique: true}
});
4.3 实现注册功能

前端(HTML + JavaScript)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>User Registration</title>
</head>
<body><form id="registerForm"><label for="username">Username:</label><input type="text" id="username" name="username" required><br><br><label for="password">Password:</label><input type="password" id="password" name="password" required><br><br><label for="email">Email:</label><input type="email" id="email" name="email" required><br><br><button type="submit">Register</button></form><script>document.getElementById('registerForm').addEventListener('submit', async function(event) {event.preventDefault();const username = document.getElementById('username').value;const password = document.getElementById('password').value;const email = document.getElementById('email').value;const response = await fetch('/register', {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({ username, password, email })});const result = await response.json();if (result.success) {alert('Registration successful!');} else {alert('Registration failed: ' + result.message);}});</script>
</body>
</html>

后端(Node.js + Express + Mongoose)

const express = require('express');
const mongoose = require('mongoose');
const bodyParser = require('body-parser');const app = express();
const port = 3000;mongoose.connect('mongodb://localhost:27017/userRegistration', {useNewUrlParser: true,useUnifiedTopology: true
});app.use(bodyParser.json());const User = require('./models/user');app.post('/register', async (req, res) => {const { username, password, email } = req.body;try {const user = new User({ username, password, email });await user.save();res.json({ success: true });} catch (err) {res.json({ success: false, message: err.message });}
});app.listen(port, () => {console.log(`Server is running on http://localhost:${port}`);
});
4.4 实现登录和注销功能

登录和注销功能的实现与注册类似,这里不再赘述。你可以参考上述代码,通过发送POST请求到/login和/logout端点来实现用户登录和注销功能。

结语

通过本文,你了解了如何在Node.js应用程序中集成MongoDB数据库,并使用Mongoose库进行数据操作。我们涵盖了MongoDB的安装、Bash命令的CRUD操作、Mongoose数据建模、关联查询与聚合管道,以及实战案例——用户注册系统的开发。希望这些内容对你有所帮助,让你能够更好地掌握Node.js与MongoDB的集成技术。

关注我!!🫵 持续为你带来Nodejs相关内容。

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

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

相关文章

大数据学习(56)-Impala

&&大数据学习&& &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 承认自己的无知&#xff0c;乃是开启智慧的大门 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一下博主哦&#x1f91…

【C#】async与await介绍

1. 实例1 1.1 代码 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace ConsoleApp1 {class Program{static void Main(string[] args){Method1();Method2();Console.ReadKey();}public static…

【大模型基础_毛玉仁】1.1 基于统计方法的语言模型

【大模型基础_毛玉仁】1.1 基于统计方法的语言模型 1.语言模型基础1.1 基于统计方法的语言模型1.1.1 n-grams 语言模型1.1.2 n-grams 的统计学原理 1.语言模型基础 语言是概率的。语言模型&#xff08;LanguageModels, LMs&#xff09;旨在准确预测语言符号的概率。 将按照语…

JavaScript(最后一个元素的索引就是数组的长度减 1)array.length - 1

在不同的编程语言中&#xff0c;表示数组中最后一个元素的方法略有不同&#xff0c;但基本思路都是利用数组的长度或索引来实现。 以下是一些常见编程语言中获取数组最后一个元素的方法&#xff1a; 1. JavaScript: 使用 array.length - 1 索引: 这是最常见和传统的方法。Java…

SpringCloud中使用服务名调用场景总结

一 API Gateway 在 Spring Cloud API Gateway 中&#xff0c;通过使用 lb:// 前缀可以实现基于服务名的负载均衡路由。以下是具体的配置和使用方法&#xff1a; 1. 配置服务注册与发现 确保你的服务已经注册到服务注册中心&#xff08;如 Nacos 或 Eureka&#xff09;。API …

7V 至 30V 的超宽 VIN 输入范围,转换效率高达 96%的WD5030

WD5030 具备 7V 至 30V 的超宽 VIN 输入范围&#xff0c;这一特性使其能够适应多种不同电压等级的供电环境&#xff0c;无论是在工业设备中常见的较高电压输入&#xff0c;还是在一些便携式设备经过初步升压后的电压&#xff0c;WD5030 都能轻松应对&#xff0c;极大地拓展了应…

深度学习模型Transformer核心组件—自注意力机制

第一章&#xff1a;人工智能之不同数据类型及其特点梳理 第二章&#xff1a;自然语言处理(NLP)&#xff1a;文本向量化从文字到数字的原理 第三章&#xff1a;循环神经网络RNN&#xff1a;理解 RNN的工作机制与应用场景(附代码) 第四章&#xff1a;循环神经网络RNN、LSTM以及GR…

利用Ollama+AnythingLLM+本地向量数据库Milvus+本地DeepSeek大模型实现知识库的搭建

1. Ollama的搭建 基本介绍 Ollama是一个支持在Windows、Linux和MacOS上本地运行大语言模型的工具。它允许用户非常方便地运行和使用各种大语言模型,比如Qwen模型等。用户只需一行命令就可以启动模型。 Ollama 下载&#xff1a;https://ollama.com/download Ollama 官方主页&a…

如何搭建个人静态住宅IP:从零开始

你好&#xff01;今天我们将一起探索如何从头开始搭建个人静态住宅IP。无论您是为了远程办公、在线教育还是游戏加速&#xff0c;静态住宅IP都能带给您更稳定的网络体验。 一、准备阶段 1. 明确需求 首先&#xff0c;您需要清楚自己为什么需要静态住宅IP。可能是为了实现远程…

国产编辑器EverEdit - 安装扩展功能的方式

1 扩展管理 1.1 应用场景 由于各行各业工作场景的不同&#xff0c;编辑器不可能为所有行业都定制功能&#xff0c;因此&#xff0c;对于一些特殊的行业应用场景&#xff0c;某些资深工程师可能已经做了一些扩展&#xff0c;并分享到了共享平台&#xff0c;普通工程师可以安装这…

CUDA计时函数:精确测量GPU代码执行时间

在GPU编程中&#xff0c;精确测量代码执行时间是性能优化的关键步骤。CUDA提供了专门的计时工具来帮助开发者准确获取核函数&#xff08;Kernel&#xff09;、内存拷贝等操作的耗时。本文将详细介绍CUDA计时函数的使用方法&#xff0c;并通过实例代码演示如何高效测量GPU代码的…

Go语言集成DeepSeek API和GoFly框架文本编辑器实现流式输出和对话(GoFly快速开发框架)

说明 本文是GoFly快速开发框架集成Go语言调用 DeepSeek API 插件&#xff0c;实现流式输出和对话功能。为了方便实现更多业务功能我们在Go服务端调用AI即DeepSeek接口&#xff0c;处理好业务后再用Gin框架实现流失流式输出到前端&#xff0c;前端使用fetch请求接收到流式的mar…

SAP服务器进程预警通知

在财务月结&#xff0c;HR薪资核算等系统用户集中使用高峰时期。通过判断判断当前系统可用的并行对话框进程数&#xff0c;用户使用过多给出提示&#xff0c;服务器进程预警通知。 1. 根据配置的进程最大可使用率80%&#xff0c;根据进程数判断&#xff1a;当进程可用数少于20%…

【Java代码审计 | 第四篇】SQL 注入防范

文章目录 Java SQL 注入防御方法类型转换预编译查询&#xff08;PreparedStatement&#xff09;使用 ORM 框架&#xff08;如 MyBatis、Hibernate&#xff09;白名单限制ORDER BY 语句LIKE 语句 限制数据库权限过滤和转义特殊字符监控与日志审计使用 Web 应用防火墙&#xff08…

软考中级-数据库-3.3 数据结构-树

定义:树是n(n>=0)个结点的有限集合。当n=0时称为空树。在任一非空树中,有且仅有一个称为根的结点:其余结点可分为m(m>=0)个互不相交的有限集T1,T2,T3...,Tm…,其中每个集合又都是一棵树,并且称为根结点的子树。 树的相关概念 1、双亲、孩子和兄弟: 2、结点的度:一个结…

选择排序算法的SIMD优化

一、优化原理 将查找数组最小值索引的SIMD优化的函数嵌入选择排序主循环,优化最耗时的最小值查找环节,同时保留选择排序的交换逻辑。 二、关键改造步骤 1)最小值查找模块化 复用SIMD优化的 find_min_index_simd函数。 2)动态子数组处理 每次循环处理 arr[i..n-1] 子数…

考网络安全工程师证要什么条件才能考?

在当今数字化时代&#xff0c;网络安全问题日益凸显&#xff0c;网络安全工程师成为了一个备受瞩目的职业。许多有志于投身这一行业的学子或职场人士&#xff0c;都希望通过考取网络安全工程师证书来提升自己的专业素养和竞争力。那么&#xff0c;考网络安全工程师证需要具备哪…

uniapp项目运行失败Error: getaddrinfo *.bspapp.com 文件查找失败uview-ui及推荐MarkDown软件 Typora

一、uniapp项目运行失败Error: getaddrinfo *.bspapp.com 文件查找失败uview-ui 在运行一个uniapp项目时&#xff0c;出现报错 文件查找失败&#xff1a;uview-ui&#xff0c;Error: getaddrinfo ENOTFOUND 960c0a.bspapp.com。hostname异常&#xff0c;报错的详细信息如下&…

使用阿里云 API 进行声音身份识别的方案

使用阿里云 API 进行声音身份识别的方案 阿里云提供 智能语音交互&#xff08;智能语音识别 ASR&#xff09; 和 声纹识别&#xff08;说话人识别&#xff09; 服务&#xff0c;你可以利用 阿里云智能语音 API 进行 说话人识别&#xff0c;实现客户身份验证。 方案概述 准备工…

【Pandas】pandas Series unstack

Pandas2.2 Series Computations descriptive stats 方法描述Series.argsort([axis, kind, order, stable])用于返回 Series 中元素排序后的索引位置的方法Series.argmin([axis, skipna])用于返回 Series 中最小值索引位置的方法Series.argmax([axis, skipna])用于返回 Series…