Node.js后端连接MySQL实战指南
node做后端连接mysql

首页 2025-07-15 11:18:56



Node.js做后端连接MySQL:构建高效、可扩展的Web应用 在当前的Web开发领域,Node.js以其非阻塞I/O模型、事件驱动架构和强大的生态系统,迅速成为构建高性能、可扩展后端服务的首选技术之一

    与此同时,MySQL作为开源的关系型数据库管理系统,以其稳定、高效和丰富的功能,被广泛应用于各种规模的应用程序中

    将Node.js与MySQL结合使用,可以充分利用两者的优势,开发出既高效又可靠的Web应用

    本文将详细介绍如何使用Node.js做后端连接MySQL数据库,构建出强大而灵活的后端服务

     一、为什么选择Node.js和MySQL 1. Node.js的优势 -非阻塞I/O模型:Node.js基于事件循环和回调机制,可以高效地处理大量并发请求,非常适合I/O密集型任务

     -丰富的生态系统:npm(Node Package Manager)拥有庞大的第三方库和工具,极大地加速了开发过程

     -跨平台支持:Node.js可以在多种操作系统上运行,包括Windows、Linux和macOS,便于开发和部署

     -JavaScript一致性:前端开发者可以轻松过渡到后端开发,因为Node.js使用JavaScript作为编程语言

     2. MySQL的优势 -稳定性和可靠性:MySQL经过数十年的发展和广泛应用,已经成为数据库领域的佼佼者,稳定性极高

     -性能优越:MySQL在处理大量数据和复杂查询时表现出色,支持多种存储引擎,满足不同场景的需求

     -开源和社区支持:MySQL是开源软件,拥有庞大的用户社区和丰富的文档资源,遇到问题可以快速找到解决方案

     -事务支持:MySQL支持ACID(原子性、一致性、隔离性、持久性)事务,保证数据的一致性和完整性

     二、搭建开发环境 在开始编码之前,确保你已经安装了以下软件: -Node.js:可以从Node.js官方网站下载并安装最新版本的LTS(长期支持)版本

     -MySQL:可以从MySQL官方网站下载并安装MySQL Server,或者使用Docker容器化部署

     -MySQL Workbench(可选):这是一个图形化管理工具,方便创建数据库、表和执行SQL查询

     安装完成后,通过命令行检查Node.js和MySQL是否安装成功: bash node -v mysql -V 三、创建Node.js项目 1.初始化项目 在终端中创建一个新的目录并进入该目录,然后运行`npm init`命令初始化项目: bash mkdir node-mysql-app cd node-mysql-app npm init -y 2.安装依赖 安装`express`框架和`mysql2`库

    `express`是一个轻量级的Node.js Web应用框架,而`mysql2`是一个流行的MySQL客户端库: bash npm install express mysql2 四、连接MySQL数据库 1.创建数据库和表 使用MySQL Workbench或命令行连接到MySQL服务器,创建一个数据库和表

    例如,创建一个名为`testdb`的数据库和一个名为`users`的表: sql CREATE DATABASE testdb; USE testdb; CREATE TABLE users( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(100) NOT NULL, email VARCHAR(100) NOT NULL UNIQUE, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); 2.配置数据库连接 在项目根目录下创建一个名为`db.js`的文件,用于配置和管理数据库连接: javascript const mysql = require(mysql2); const connection = mysql.createConnection({ host: localhost, // 数据库主机地址 user: root,// 数据库用户名 password: password, // 数据库密码 database: testdb// 数据库名称 }); connection.connect((err) =>{ if(err){ console.error(Error connecting to the database:, err.stack); return; } console.log(Connected to the MySQL server.); }); module.exports = connection; 3.创建Express服务器 在项目根目录下创建一个名为`server.js`的文件,用于创建和配置Express服务器: javascript const express = require(express); const bodyParser = require(body-parser); const connection = require(./db); const app = express(); const PORT = process.env.PORT ||3000; // 中间件 app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: true})); //路由 app.get(/,(req, res) =>{ res.send(Hello, World!); }); // 获取用户列表 app.get(/users,(req, res) =>{ const sql = SELECTFROM users; connection.query(sql,(error, results) =>{ if(error) throw error; res.json(results); }); }); // 创建新用户 app.post(/users,(req, res) =>{ const{ name, email} = req.body; const sql = INSERT INTO users(name, email) VALUES(?, ?); connection.query(sql,【name, email】,(error, results) =>{ if(error) throw error; res.status(201).json({ id: results.insertId, ...req.body}); }); }); // 启动服务器 app.listen(PORT,() =>{ console.log(`Server is runn

nat123映射怎么用?超详细步骤,外网访问内网轻松搞定
nat123域名怎么用?两种方式轻松搞定
nat123怎么用?简单几步实现内网穿透
内网穿透工具对比:nat123、花生壳与轻量新选择
远程访问内网很简单:用对工具,一“箭”穿透
ngrok下载完全指南:从入门到获取客户端
内网远程桌面软件:穿透局域网边界的数字窗口
从外网远程访问内网服务器的完整方案
Windows Server 2008端口转发完全教程:netsh命令添加/查看/删除/重置
为什么三层交换机转发比Linux服务器快?转发表硬件加速的秘密