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就封装完成了。然后就可以进行我们的开发了。

相关推荐
皇族崛起1 小时前
【视觉多模态】- 3D建模尝试 I (广场3D建模,失败)
数据库·人工智能·3d·性能优化
JavaLearnerZGQ1 小时前
redis笔记大全
数据库·redis·笔记
资生算法程序员_畅想家_剑魔1 小时前
Java常见技术分享-26-事务安全-锁机制-作用与分类
java·开发语言·数据库
Vic101011 小时前
PostgreSQL 中 nextval() 的线程安全性解析
java·数据库·postgresql
写代码的小阿帆2 小时前
Redis缓存健壮性——穿透、雪崩与击穿防护
数据库·redis·缓存
L1624762 小时前
linux环境安装MySQL的详细步骤(二进制包形式)
linux·运维·mysql
wangqiaowq2 小时前
使用 mysqldump 导出 + mysql 导入
数据库
默默在路上2 小时前
CentOS Stream 9 安装mysql8.0
linux·mysql·centos
qq_317620313 小时前
第23章-中级项目练习案例(15个)
数据库·爬虫·web开发·python项目·api开发·python案例
是三好3 小时前
SQL 性能分析及优化
android·数据库·sql