使用node.js实现对数据库进行CRUD操作

 更新时间:2024年12月28日 13:36:03   作者:土豆炒马铃薯。  
这篇文章主要为大家详细介绍了如何使用node.js实现对数据库进行CRUD(增删改查)操作,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下

在JavaScript中直接连接数据库并进行增删改查(CRUD)操作通常不推荐这么做,因为JavaScript(尤其是前端JavaScript)无法直接连接数据库,出于安全性和架构设计考虑。一般来说,应该通过后端服务(例如Node.js、Express等)来与数据库进行交互,前端通过API请求与后端通信。

以下是一个完整的示例,展示如何使用Node.js与MySQL数据库进行CRUD操作:

安装必要的依赖

首先,确保你已经安装了Node.js。然后使用以下命令初始化一个新的Node.js项目并安装依赖:

npm init -y
npm install express mysql2 body-parser

创建数据库(MySQL)

在MySQL中创建一个数据库和表,例如:

CREATE DATABASE sportsms;

USE sportsms;

​​​​​​​CREATE TABLE athletes (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    age INT,
    event VARCHAR(100)
);

创建Node.js应用

创建一个名为 app.js 的文件,示例代码如下:

const express = require('express');
const mysql = require('mysql2');
const bodyParser = require('body-parser');

const app = express();
const port = 3000;

// 使用body-parser来解析JSON请求体
app.use(bodyParser.json());

// 创建数据库连接池
const db = mysql.createPool({
  host: 'localhost',
  user: 'root',         // MySQL用户名
  password: '',         // MySQL密码
  database: 'sportsms'  // 数据库名称
});

// 测试数据库连接
db.getConnection((err, connection) => {
  if (err) {
    console.error('数据库连接失败:', err.stack);
    return;
  }
  console.log('成功连接到数据库');
  connection.release();
});

// 创建选手(增)
app.post('/athletes', (req, res) => {
  const { name, age, event } = req.body;

  const query = 'INSERT INTO athletes (name, age, event) VALUES (?, ?, ?)';
  db.query(query, [name, age, event], (err, result) => {
    if (err) {
      return res.status(500).json({ error: '数据库错误', details: err });
    }
    res.status(201).json({ id: result.insertId, name, age, event });
  });
});

// 获取所有选手(查)
app.get('/athletes', (req, res) => {
  db.query('SELECT * FROM athletes', (err, results) => {
    if (err) {
      return res.status(500).json({ error: '数据库错误', details: err });
    }
    res.json(results);
  });
});

// 获取单个选手(查)
app.get('/athletes/:id', (req, res) => {
  const { id } = req.params;
  db.query('SELECT * FROM athletes WHERE id = ?', [id], (err, results) => {
    if (err) {
      return res.status(500).json({ error: '数据库错误', details: err });
    }
    if (results.length === 0) {
      return res.status(404).json({ error: '选手未找到' });
    }
    res.json(results[0]);
  });
});

// 更新选手(改)
app.put('/athletes/:id', (req, res) => {
  const { id } = req.params;
  const { name, age, event } = req.body;

  const query = 'UPDATE athletes SET name = ?, age = ?, event = ? WHERE id = ?';
  db.query(query, [name, age, event, id], (err, result) => {
    if (err) {
      return res.status(500).json({ error: '数据库错误', details: err });
    }
    if (result.affectedRows === 0) {
      return res.status(404).json({ error: '选手未找到' });
    }
    res.json({ id, name, age, event });
  });
});

// 删除选手(删)
app.delete('/athletes/:id', (req, res) => {
  const { id } = req.params;
  db.query('DELETE FROM athletes WHERE id = ?', [id], (err, result) => {
    if (err) {
      return res.status(500).json({ error: '数据库错误', details: err });
    }
    if (result.affectedRows === 0) {
      return res.status(404).json({ error: '选手未找到' });
    }
    res.status(204).send();
  });
});

// 启动服务器
app.listen(port, () => {
  console.log(`服务器正在运行,访问 http://localhost:${port}`);
});

启动服务器

在命令行中,运行以下命令启动服务器:

node app.js

测试API

你可以使用工具如Postman或者直接用 curl 来测试API。以下是各个操作的示例请求:

增 - 创建选手:

POST /athletes

请求体(JSON):

{
  "name": "John Doe",
  "age": 25,
  "event": "100m Sprint"
}

查 - 获取所有选手:

GET /athletes

响应(JSON):

[
  {
    "id": 1,
    "name": "John Doe",
    "age": 25,
    "event": "100m Sprint"
  }
]

查 - 获取单个选手:

GET /athletes/1

响应(JSON):

{
  "id": 1,
  "name": "John Doe",
  "age": 25,
  "event": "100m Sprint"
}

改 - 更新选手信息:

PUT /athletes/1

请求体(JSON):

{
  "name": "John Doe",
  "age": 26,
  "event": "200m Sprint"
}

删 - 删除选手:

DELETE /athletes/1

这就是一个简单的Node.js和MySQL连接并进行增删改查(CRUD)操作的完整示例。你可以通过前端使用JavaScript发送HTTP请求与后端交互。注意,直接在前端处理数据库操作是不安全的,前端应仅通过API请求与后端交互。

到此这篇关于使用node.js实现对数据库进行CRUD操作的文章就介绍到这了,更多相关node.js数据库CRUD操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解如何在NodeJS应用程序中处理多个API请求

    详解如何在NodeJS应用程序中处理多个API请求

    NodeJS默认是异步的,这意味着它已经能够同时处理多个请求,但它只适用于I/O操作,如HTTP请求、文件系统操作、数据库查询、实时聊天应用等,在处理CPU密集型任务时,可能需要很长时间,这就是为什么NodeJS提供了一些我们将在下面介绍的特定包
    2023-12-12
  • Ubuntu22.04系统下升级nodejs到v18版本

    Ubuntu22.04系统下升级nodejs到v18版本

    ubuntu默认安装的nodejs版本比较老,要安装到最新的,下面这篇文章主要给大家介绍了关于Ubuntu22.04系统下升级nodejs到v18版本的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • node.js中的console.timeEnd方法使用说明

    node.js中的console.timeEnd方法使用说明

    这篇文章主要介绍了node.js中的console.timeEnd方法使用说明,本文介绍了console.timeEnd的方法说明、语法、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12
  • Node.js Webpack常见的模式详解

    Node.js Webpack常见的模式详解

    这篇文章主要介绍了Node.js Webpack常见的模式,Webpack的另一个核心是Plugin ,Plugin是可以用于执行更加广泛的任务如打包优化资源管理 环境变量注入等,需要的朋友可以参考下
    2022-10-10
  • 详解node如何让一个端口同时支持https与http

    详解node如何让一个端口同时支持https与http

    众所周知node是一个高性能的web服务器,使用它可以很简单的创建一个http或https的服务器。这篇文章主要介绍了详解node如何让一个端口同时支持https与http
    2017-07-07
  • Node.js中如何合并两个复杂对象详解

    Node.js中如何合并两个复杂对象详解

    下面这篇文章主要给大家介绍了在Node.js中如何合并两个复杂对象的方法,文中给出了详细的示例代码,相信对大家的理解和学习具有一定的参考借鉴价值,有需要的朋友可以参考,下面来一起看看吧。
    2016-12-12
  • 使用 Node.js和Express搭建服务器的过程步骤详解

    使用 Node.js和Express搭建服务器的过程步骤详解

    Node.js 是一个开源、跨平台的 JavaScript 运行时环境,这篇文章主要介绍了如何使用 Node.js和Express搭建服务器,需要的朋友可以参考下
    2023-09-09
  • nvm管理node无法正常切换node版本问题的解决方法

    nvm管理node无法正常切换node版本问题的解决方法

    相信一定会有存在一些小伙伴 明明都已经按着操作卸载node 和安装nvm 了但是 依旧无法正常通过nvm管理node,本文将给大家介绍nvm管理node无法正常切换node版本问题的解决方法,需要的朋友可以参考下
    2024-01-01
  • Node.js 获取微信JS-SDK CONFIG的方法示例

    Node.js 获取微信JS-SDK CONFIG的方法示例

    这篇文章主要介绍了Node.js 获取微信JS-SDK CONFIG的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 利用Decorator如何控制Koa路由详解

    利用Decorator如何控制Koa路由详解

    最近学习了plover的底层框架koa,所以下面这篇文章主要给大家介绍了关于利用Decorator如何控制Koa路由的相关资料,,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来随着小编一起学习学习吧
    2018-06-06

最新评论