《Node.JS学习—下篇》Nodejs+Express项目连接Mysql数据库的处理

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 本篇文章,接着上篇《Node.JS学习—上篇》(1)在express工程目录下,新建一个db.js,下面的实例,我将其放到了config目录下:image.
+关注继续查看

本篇文章,接着上篇《Node.JS学习—上篇》
(1)在express工程目录下,新建一个db.js,下面的实例,我将其放到了config目录下:

img_6be8ecef6a5002324f4efe44302116b7.png
image.png

(2)使用连接池连mysql,建立与远端数据库的连接

db.js
var mysql = require("mysql");
var pool = mysql.createPool({
  host: '101.201.121.110',//主机
  port: 3306,//端口号
  user: 'xxx',//MySQL认证用户名
  password: 'xxxxxx',//MySQL认证用户密码
  database: 'databaseName'  //数据库名称
});

function query(sql,callback){
  pool.getConnection(function(err,connection){
    connection.query(sql, function (err,rows) {
      callback(err,rows);
      connection.release();
    });
  });
}
exports.query = query;

(3)路由配置:在项目目录下的app.js中配置路由

app.js

img_8075c0a0a6898f84d4c7c80fc1aa8bc2.png
image.png

(4)新建一个search.js,写一个简单的查询,测试连接数据库是否成功。
运行项目(cmd进入项目目录,执行npm start),在浏览器输入:http://localhost:3000/search 测试结果。

【测试结果如下】:awards是俺写的抽奖活动相关的接口中涉及到的一个奖品表。为了让学习的小伙伴能看到效果,真是用心良苦呀,哈哈~~~


img_3deeaee4608fb28038204ff5935588c2.png
image.png
search.js
var express = require('express');
var router = express.Router();

var db = require("../config/db");
const Unity = require('../unity/Unity');//Unity为一个工具类
const r = Unity.send;

/**
 * search
 */
router.get('/', function(req, res, next) {
    db.query("select * from awards",function (error, rows) {
        if (error) {
            res.send(r('', 200, 1, 'error'));
        } else {
            res.send(r(rows));
        }
    })
});
module.exports = router;//不加这句会报错: Router.use() requires a middleware function but got a Object (没有向外暴露,导致app.use引用不到)
Unity.js
/**
 * 统一返回数据的工具类
 */

class Unity {
  /**
   * 统一返回参数
   * @param {object} data - 返回对象;
   * @param {number} code - 状态码,默认为200-成功;
   * @param {number} status - 成功为1, 失败为0,默认为1;
   */
  send(data, code = 200, status = 1, msg = 'success') {
    if (status) {
      return {
        data: data,
        code: code,
        msg: msg
      };
    } else {
      return {
        code: code,
        data: [],
        msg: data
      };
    }
  }
}

module.exports = new Unity();

参考文章:nodejs进阶(6)—连接MySQL数据库示例

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
存储 开发框架 JavaScript
Express框架的学习介绍
Express框架的学习介绍
60 0
|
11月前
|
JSON JavaScript 中间件
node.js 学习入门(07 - express 模块创建基本 web 服务器)(下)
node.js 学习入门(07 - express 模块创建基本 web 服务器)
|
11月前
|
JavaScript 中间件
node.js 学习入门(07 - express 模块创建基本 web 服务器)(上)
node.js 学习入门(07 - express 模块创建基本 web 服务器)
|
数据格式
express学习47-服务器响应的数据格式
express学习47-服务器响应的数据格式
98 0
express学习47-服务器响应的数据格式
express学习42-多人管理33修改2(未能完结
express学习42-多人管理33修改2(未能完结
39 0
express学习42-多人管理33修改2(未能完结
express学习43-ajax的运行环境
express学习43-ajax的运行环境
53 0
express学习43-ajax的运行环境
express学习45-ajax的运行原理
express学习45-ajax的运行原理
70 0
express学习45-ajax的运行原理
express学习46-ajax实现步骤
express学习46-ajax实现步骤
65 0
express学习46-ajax实现步骤
express学习41-多人管理32修改
express学习41-多人管理32修改
58 0
express学习41-多人管理32修改
推荐文章
更多