创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

这篇具有很好参考价值的文章主要介绍了创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文为博主原创,转载请注明出处:

1.使用npm进行初始化

  在本地创建项目的文件夹名称,如 node_test,并在该文件夹下进行黑窗口执行初始化命令

创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

 2. 安装 expres包和myslq依赖包

npm i express@4.17.1 mysql2@2.2.5

            创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

  Express是一个流行的Web应用程序框架,可以帮助我们快速构建Web应用程序和API。Express提供了许多有用的功能,包括路由、中间件、请求响应、错误处理等,使得开发Web应用程序变得简单而快速。 具体来说,Express的依赖实现了以下功能:

  • 路由:Express可以通过路由来定义URL和HTTP方法之间的映射关系,使得我们可以根据不同的URL和HTTP方法提供不同的响应。
  • 中间件:中间件是在请求和响应之间执行的函数,可以对请求进行处理、修改响应或者终止请求-响应循环。Express的中间件机制非常灵活,可以通过多个中间件来完成复杂的业务逻辑。
  • 请求响应:Express提供了方便的API来处理请求和响应,包括读取请求体、设置响应头、发送响应体等。
  • 错误处理:在开发Web应用程序时,难免会遇到一些错误,例如找不到资源、参数错误等等。Express提供了方便的API来处理这些错误,使得我们可以轻松地返回正确的HTTP响应。

3.项目架构

  项目的整体结构如下:

                                    创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

 3.1 在项目的根目录下创建app.js

const express = require('express')
const router = require('./routes/router')
const app = express()
app.use(express.json())
app.use('/users', router)
app.listen(3000, () => {
  console.log('Server started on port 3000')
})

3.2 创建models文件夹,包含所有数据库层面的方法

3.2.1 创建db.js,配置数据库

const mysql = require('mysql2')
const pool = mysql.createPool({
  host: 'localhost',
  user: 'root',
  password: 'password',
  database: 'test_db',
  waitForConnections: true,
  connectionLimit: 10,
  queueLimit: 0
})
module.exports = pool

3.2.2创建 models/userModel.js ,编写用户的新增、修改、删除、查询相关的mysql实现

const pool = require('./db')
function getAllUsers() {
  return new Promise((resolve, reject) => {
    pool.query('SELECT * FROM users', (err, rows) => {
      if (err) {
        reject(err)
      } else {
        resolve(rows)
      }
    })
  })
}
function getUserById(id) {
  return new Promise((resolve, reject) => {
    pool.query('SELECT * FROM users WHERE id = ?', [id], (err, rows) => {
      if (err) {
        reject(err)
      } else {
        resolve(rows[0])
      }
    })
  })
}
function createUser(user) {
  return new Promise((resolve, reject) => {
    pool.query('INSERT INTO users SET ?', user, (err, result) => {
      if (err) {
        reject(err)
      } else {
        resolve(result.insertId)
      }
    })
  })
}
function updateUser(id, user) {
  return new Promise((resolve, reject) => {
    pool.query('UPDATE users SET ? WHERE id = ?', [user, id], (err, result) => {
      if (err) {
        reject(err)
      } else {
        resolve(result.affectedRows)
      }
    })
  })
}
function deleteUser(id) {
  return new Promise((resolve, reject) => {
    pool.query('DELETE FROM users WHERE id = ?', [id], (err, result) => {
      if (err) {
        reject(err)
      } else {
        resolve(result.affectedRows)
      }
    })
  })
}
module.exports = {
  getAllUsers,
  getUserById,
  createUser,
  updateUser,
  deleteUser
}

3.3 创建请求处理的controller

  在根目录下创建controllers文件夹,并在该目录下创建 userController.js

const userModel = require('../models/userModel')
async function getAllUsers(req, res) {
  try {
    const users = await userModel.getAllUsers()
    res.json(users)
  } catch (err) {
    console.error(err)
    res.sendStatus(500)
  }
}
async function getUserById(req, res) {
  try {
    const user = await userModel.getUserById(req.params.id)
    if (user) {
      res.json(user)
    } else {
      res.sendStatus(404)
    }
  } catch (err) {
    console.error(err)
    res.sendStatus(500)
  }
}
async function createUser(req, res) {
  try {
    const id = await userModel.createUser(req.body)
    res.json({ id })
  } catch (err) {
    console.error(err)
    res.sendStatus(500)
  }
}
async function updateUser(req, res) {
  try {
    const rowsAffected = await userModel.updateUser(req.params.id, req.body)
    if (rowsAffected) {
      res.sendStatus(204)
    } else {
      res.sendStatus(404)
    }
  } catch (err) {
    console.error(err)
    res.sendStatus(500)
  }
}
async function deleteUser(req, res) {
  try {
    const rowsAffected = await userModel.deleteUser(req.params.id)
    if (rowsAffected) {
      res.sendStatus(204)
    } else {
      res.sendStatus(404)
    }
  } catch (err) {
    console.error(err)
    res.sendStatus(500)
  }
}
module.exports = {
  getAllUsers,
  getUserById,
  createUser,
  updateUser,
  deleteUser
}

3.4编写路由文件

  项目根目录下创建routers文件夹,并创建路由文件 router.js

const express = require('express')
const router = express.Router()
const userController = require('../controllers/userController')
router.get('/getAllUsers', userController.getAllUsers)
router.get('/getUserById/:id', userController.getUserById)
router.post('/createUser', userController.createUser)
router.put('/updateUser/:id', userController.updateUser)
router.delete('/deleteUser/:id', userController.deleteUser)
module.exports = router

 通过以上代码,我们可以实现对用户表的增删改查操作,使用Node.js和MySQL构建一个简单的用户管理系统。 

4.启动项目

  进入到项目的根目录下,运行以下命令:

node app.js

  如果一切正常,控制台会输出“Server started on port 3000”,表示项目已经成功启动。   

           创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

5.调试项目

  可以使用Node.js自带的调试器——node inspect指令。在项目的根目录下运行以下命令:

node inspect app.js

  然后可以打开Chrome浏览器,在地址栏输入chrome://inspect,点击“Open dedicated DevTools for Node”即可开始调试。 在调试过程中,可以在代码中设置断点,查看变量的值,单步执行等等操作,帮助找出代码中的问题。 

                 创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作

         文章来源地址https://www.toymoban.com/news/detail-461486.html

到了这里,关于创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【MySQL】表的增删改查——MySQL基本查询、数据库表的创建、表的读取、表的更新、表的删除

         CURD是一个数据库技术中的缩写词,它代表Create(创建),Retrieve(读取),Update(更新),Delete(删除)操作。 这四个基本操作是数据库管理的基础,用于处理数据的基本原子操作。      在MySQL中,Create操作是十分重要的,它帮助用于创建数据库对象,如数据

    2024年03月18日
    浏览(45)
  • 微信小程序开发教程:使用WebStorm,创建第一个NodeJS项目

    要使用 WebStorm 创建第一个 Node.js 项目,请按照以下步骤操作: 步骤 1:安装 WebStorm 如果你还没有安装 WebStorm,你需要先下载并安装它。你可以从 JetBrains 官网下载 WebStorm 的最新版本: https://www.jetbrains.com/webstorm/download/ 按照安装向导完成安装过程。 步骤 2:打开 WebStorm 启动

    2024年02月19日
    浏览(33)
  • mysql用户相关操作

    一、如何查看系统存在多少用户?  相关命令: 二、如何查看用户是否设置密码? 在 MySQL 中,用户密码是被加密的,不可以直接查看用户密码; 1 查看用户是否设置了密码: 可以使用以下命令来查看用户是否设置了密码  相关sql语句: 2 如果设置了密码,如何重新修改用户

    2024年02月11日
    浏览(19)
  • 【Java项目】SpringBoot项目完成微信公众号收到用户消息自动回复功能附带视频(超详细)

    视频讲解 首先你需要先注册一个你的微信公众号 微信公众号平台 然后打开下面的自动回复功能 之后进入到你的开发者中心 开发者中心基本配置 然后生成你的开发者密码,开发者id,以及设置你的IP白名单。 这里的IP白名单中的IP必须是一个公网IP,因为微信官方会把他们的

    2024年02月13日
    浏览(40)
  • Flask 项目怎么配置并创建第一个小项目?附上完成第一个小案例截图

    目录 1. 为什么要学习 flask? 2. flask 是什么? 3. flask 如何使用? 要安装 Flask,可以按照以下步骤进行: 4. 使用流程 4.1. 新建项目 4.1.1. 打开 pycharm,新建项目 4.1.2. 设置目录,并添加环境 4.1.3. 找到之前创建的虚拟环境 4.1.4. 然后点击 OK 4.1.5. 注意,项目目录和环境目录不一样

    2024年01月16日
    浏览(39)
  • 创建Firebase项目并接入Firebase推送: Firebase Cloud Messaging (FCM)

    Firebase Cloud Messaging (FCM) 是一种跨平台消息传递解决方案,可供您可靠地传递消息,而且还是免费的服务。支持 Android,IOS,Web,Flutter,Unity. 消息类型 可以使用 FCM 向客户端发送两种类型的消息: 通知消息,有时被称为“显示消息”。此类消息由 FCM SDK 自动处理。 数据消息,由客

    2024年02月04日
    浏览(28)
  • Tomcat的基本使用,如何用Maven创建Web项目、开发完成部署的Web项目

    Web服务器: Web服务器是一个应用程序(软件),对HTTP协议的操作进行封装,使得程序员不必直接对协议进行操作,让Web开发更加便捷。 主要功能是“提供网上信息浏览服务”。 Tomcat: Tomcat是Apache软件基金会一个核心项目,是一个开源免费的轻量级Web服务器,支持Servlet/JS

    2024年02月15日
    浏览(40)
  • 基于NodeJs+Express+MySQL 实现的个人博客完整项目

    目录 一、创建项目并初始化 项目结构 二、安装项目所需要的包 三、创建所需要的数据库表 表 user 用于存放账户密码 表 notepad 用于存放文章数据 表 leaving 用于存放留言板的数据 三、编写app.js文件 1、导入所有需要的包 2、创建web服务器 3、创建db文件夹,在文件夹里面创建

    2024年02月08日
    浏览(41)
  • mysql创建用户以及给用户授予权限

    说明: username——你将创建的用户名, password——该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器. 进入到mysql的客户端,在下图中可以看到,创建了一个用户名为 xaiodong 并且密码为 123456 的用户 这个时候创建的改用户只能看见一个库, information_schem

    2024年02月07日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包