使用 Node.js + Express+MySQL 实现简单的增删改查

在上篇文章 使用 Node.js + Express开发服务端 已经学习了NodeJS+Express基本用法,其中API接口返回的数据是假数据,并没有关联数据库查询。在本篇文章中我们将实现基本的数据交互并实现简单的增删改查。如果你还未阅读上篇文章请移步阅读~~~

1. 在上篇文章的项目基础上配置MySQL

确保你电脑中已安装了MySQL环境,我们使用的IDE为Navicat. 新建test数据库并新建一个 Table命名为 user,添加几条数据(用于查询)

user表

Mysql的准备到此就准备完成,接下来是我们本篇教程的重点,怎样使用NodeJS+Express链接MySQL

2. 安装MySQL模块

打开我们刚刚创建的 node_express工程 这里我使用的是Visual Studio Code

node_express工程

接着执行如下命令

npm install 安装mysql依赖

接着我们向工程中添加一个 db 目录 用于存放MySQL配置信息
并在 db 目录总新建一个 DBConfig.js 文件并添加如下内容

//mysql数据库配置
module.exports = {
  mysql: {
    host:'127.0.0.1',
    port:'3306',
    user:'root',
    password:'这里填写你的mysql的连接密码',
    database:'test'
  }
}

3. 添加API接口调用SQL语句

紧接着继续在 db目录中添加 Usersql.js 并键入如下内容

var UserSQL = {  
    insert:'INSERT INTO User(name,gender,age) VALUES(?,?,?)', 
    queryAll:'SELECT * FROM user',  
    getUserById:'SELECT * FROM user WHERE id = ? ',
  };
module.exports = UserSQL;

Usersql.js 的主要作用是提供增删改查sql语句。

 改动routes 目录中的users.js 向外暴露我们操作 User 的API接口。
这里我只在 users.js 中添加一个 addUser/getAll 接口 内容如下

var express = require('express');
var router = express.Router();
//导入MySQL模块
var mysql = require('mysql');
var dbConfig = require('../db/DBConfig');
var userSQL = require('../db/Usersql');
//使用DBConfig.js的配置信息创建一个MySQL连接池
var pool = mysql.createPool(dbConfig.mysql);
//响应一个JSON数据
var responseJSON = function(res, ret){
  if(typeof ret === 'undefined'){
    res.json({
      code:'-200',
      msg:'操作失败'
    });
  }else{
    res.json(ret);
  }
};
//添加用户
router.get('/addUser', function(req, res, next){
  //从连接池获取连接
  pool.getConnection(function(err, connection){
    //获取前台页面传过来的参数
    var param = req.query || req.params;
    //建立连接 添加一个用户信息
    connection.query(userSQL.insert, [param.name,param.gender,param.age], function(err, result){
      if(result){
        result = {
          code:200,
          msg:'添加成功'
        };
      }

      //以json形式,把操作结果返回给前台页面
      responseJSON(res, result);

      //释放连接
      connection.release();

    });
  });
});

//查询所有用户
//添加用户
router.get('/getAll', function(req, res, next){
  //从连接池获取连接
  pool.getConnection(function(err, connection){
    // //获取前台页面传过来的参数
    // var param = req.query || req.params;
    //建立连接 添加一个用户信息
    connection.query(userSQL.queryAll, function(err, result){
      console.log(result);

      //以json形式,把操作结果返回给前台页面
      responseJSON(res, result);

      //释放连接
      connection.release();

    });
  });
});

module.exports = router;

接着重新启动服务器 在浏览器访问,或者用Postman都可以

http://127.0.0.1:3000/users/getAll

getAll返回结果

http://127.0.0.1:3000/users/addUser?name=helloMysql&gender=1&age=18

{
    "code": 200,
    "msg": "添加成功"
}

其他sql的语法大家可以自行体验,这里就不在一一赘述,如果你在测试过程中遇到问题欢迎留言交流.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值