开发者社区> 懂音乐码虫> 正文

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

简介: 本篇文章,接着上篇《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数据库示例

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何处理Angular依赖注入的错误消息: NullInjectorError No provider for EffectsRootModule!
如何处理Angular依赖注入的错误消息: NullInjectorError No provider for EffectsRootModule!
42 0
InnoDB的数据页结构
页是InnoDB存储引擎管理数据库的最小磁盘单位。页类型为B-tree node的页,存放的即是表中行的实际数据了。 InnoDB数据页由以下七个部分组成,如图所示: File Header(文件头)。
807 0
Node.js开发手册(四)-Redis数据库访问
Node.js开发手册(四)-Redis数据库访问 因工作太忙,本系列的文章中断了很久,现在有机会继续了。 大家要记住,Node.js主要用于构建高性能、高可伸缩性的服务器和客户端应用,它面向的是“实时Web”。
937 0
nodeJS与MySQL实现分页数据以及倒序数据
大家在做项目时肯定会遇到列表类的数据,如果在前台一下子展示,速度肯定很慢,那么我们可以分页展示,比如说100条数据,每10条一页,在需要的时候加载一页,这样速度肯定会变快了。 那么这里我给大家介绍如何在nodejs环境中用mysql实现分页。
70 0
技能学习:学习使用node.js + vue.js,开发前端全栈网站-1.工具和本地环境
Node.js 运行环境是引领前端开发人员的“一道光”,让前端开发人员**仅**利用已掌握的 js 语言就可以实现对网站服务器环境的搭建与运行。打破了以往前后端分工合作、交流对接的惯性习惯。 相对于传统PHP、JAVA开发,Node.js 附带的npm更方便、快捷地让前端开发人员更快、更方便地使用和获取其他前端大神封装好的 js 类库和精美UI样式库,舍去不同语言和不同编码的切换过程。
362 0
网站Web项目树形菜单的实现过程(ExtJS+SpringMVC+Spring+Hibernate+MySQL)
常见的OA或者bbs或者网站,左侧往往带有菜单,使用者就可以通过菜单项进入响应的功能模块或者板块或者专区,如下所示:PKU的BBS明显使用了ExtJS的海王星主题,而且使用的就是普通的tabPanel组件实现的菜单。
2345 0
TypeScript在node项目中的实践
TypeScript在node项目中的实践 TypeScript可以理解为是JavaScript的一个超集,也就是说涵盖了所有JavaScript的功能,并在之上有着自己独特的语法。最近的一个新项目开始了TS的踩坑之旅,现分享一些可以借鉴的套路给大家。
1147 0
+关注
懂音乐码虫
一个被音乐和厨房耽误了的移动应用开发工程师。喜欢学习新技术,热爱交流学习......
18
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载