node封装mysql

封装sql

项目中要使用express,肯定要使用路由进行多模块开发,每一个模块都创建一个sql实例,就太麻烦了,把sql抽离出来,进行一些封装,让代码看起来更加优雅。

1、新建一个config目录

目录下是baseData.js和sql.js两个文件

2、basedata.js里面放数据库配置

module.exports = {
    host: 'rm-xxxxxx.mysql.zhangbei.rds.aliyuncs.com',	// 连接的服务器
    user: 'jerry',	// 用户名
    password: '@xxxxxx',	// 用户密码
    database: 'pt'	// 选择的库
}

3、sql.js里面用来暴露一个方法

var mysql = require('mysql');
var database = require('./config')
//向外暴露方法
module.exports = {
    query : function(sql,params,callback){
        //每次使用的时候需要创建链接,数据操作完成之后要关闭连接
        var connection = mysql.createConnection(database);        
        connection.connect(function(err){
            if(err){
                console.log('数据库链接失败');
                throw err;
            }
         //开始数据操作
         //传入三个参数,第一个参数sql语句,第二个参数sql语句中需要的数据,第三个参数回调函数
        connection.query( sql, params, function(err,results,fields ){
           if(err){
                console.log('数据操作失败');
                throw err;
            }
            //将查询出来的数据返回给回调函数
            callback && callback(results, fields);
            //results作为数据操作后的结果,fields作为数据库连接的一些字段
            //停止链接数据库,必须再查询语句后,要不然一调用这个方法,就直接停止链接,数据操作就会失败
             connection.end(function(err){
                  if(err){
                      console.log('关闭数据库连接失败!');
                      throw err;
                  }
              });
           });
       });
    }
};

每次使用的时候需要创建连接,数据操作完成之后需要关闭连接。因此,我们需要封装一个方法。

3、修改index.js

刚才的index.js就可以直接引入封装好的sql了

var db = require("../config/sql")

app.get('/api/get', function (req, res) {
    db.query('SELECT * FROM name', (err, results, fields) => {
        if(err){
            console.log(err);
        }
        res.json({
            method: 'GET',
            data: results
        })
    })
});   

sql就封装完成了。然后就可以进行我们的开发了。

相关推荐
FIN技术铺3 小时前
Redis集群模式之Redis Sentinel vs. Redis Cluster
数据库·redis·sentinel
内核程序员kevin4 小时前
在Linux环境下使用Docker打包和发布.NET程序并配合MySQL部署
linux·mysql·docker·.net
CodingBrother4 小时前
MySQL 中的 `IN`、`EXISTS` 区别与性能分析
数据库·mysql
kayotin4 小时前
Wordpress博客配置2024
linux·mysql·docker
代码小鑫4 小时前
A027-基于Spring Boot的农事管理系统
java·开发语言·数据库·spring boot·后端·毕业设计
小小不董5 小时前
Oracle OCP认证考试考点详解082系列16
linux·运维·服务器·数据库·oracle·dba
甄臻9245 小时前
Windows下mysql数据库备份策略
数据库·mysql
内蒙深海大鲨鱼5 小时前
qt之ui开发
数据库·qt·ui
杀神lwz5 小时前
Java 正则表达式
java·mysql·正则表达式
不爱学习的YY酱5 小时前
【计网不挂科】计算机网络第一章< 概述 >习题库(含答案)
java·数据库·计算机网络