express mysql连接池_Nodejs Mysql连接池封装

RT,把之前写的Nodejs请求Mysql的方法优化了一下,废话不多说直接上代码:

npm install mysql --save

新建文件mysql.js

/**

* Date: 2020/10/28

* Auth: LiHuYong

* Desc: 数据库连接封装

*/

const mysql = require('mysql');

let db = {};

let pool = mysql.createPool({

host: 'localhost',

user: 'root',

password: 'root',

port: '3306',

database: 'dataTable',

connectionLimit: 10,

timezone: "08:00",

multipleStatements: true // 开启同时执行多条SQL

});

db.query = function(params, callback){

if (!params.sql) {

console.log('SQL IS EMPTY');

params.res.send({code: -1, msg: "SQL IS EMPTY"});

return;

}

pool.getConnection(function(err, connection){

connection.query(params.sql, params.sqlParams, function(err, results){

if(err){

console.log('[QUERY ERROR] - ', err.message);

params.res.send({code: -1, msg: "服务异常"});

}else{

callback(results);

}

connection.release();

});

});

};

module.exports = db;

项目中使用

// 这里我用了Express Router,具体在用的时候看自己项目路由时如何配置的就行

const express = require("express");

const router = express.Router();

const db = require('../mysql'); // 引入封装的模块

router.get("/list", function (req, res) {

// 关键代码

db.query({

req: req,

res: res,

sql: "SELECT * FROM table",

sqlParams: []

}, function(result){

res.send({code: 0, result: result});

});

});

module.exports = router;

3be53711dbe93adad42a0563cdeaa5f3.png

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是封装nodejs使用mysql2的连接池的写法: ```javascript const mysql = require('mysql2/promise'); class MysqlPool { constructor(config) { this.pool = mysql.createPool(config); } async execute(sql, values) { const connection = await this.pool.getConnection(); try { const [rows] = await connection.execute(sql, values); return rows; } catch (err) { throw err; } finally { connection.release(); } } async beginTransaction() { const connection = await this.pool.getConnection(); try { await connection.beginTransaction(); return connection; } catch (err) { connection.release(); throw err; } } async commitTransaction(connection) { try { await connection.commit(); connection.release(); } catch (err) { await connection.rollback(); connection.release(); throw err; } } async rollbackTransaction(connection) { try { await connection.rollback(); connection.release(); } catch (err) { connection.release(); throw err; } } } module.exports = MysqlPool; ``` 在上面的代码中,我们使用了 `mysql2/promise` 模块创建了一个连接池,然后封装了一些常用的方法,包括 `execute`、 `beginTransaction`、 `commitTransaction` 和 `rollbackTransaction`。其中,`execute` 方法用于执行 SQL 语句,`beginTransaction` 方法用于开启事务,`commitTransaction` 方法用于提交事务,`rollbackTransaction` 方法用于回滚事务。 使用时,只需要实例化 `MysqlPool` 类,然后调用相应的方法即可。例如: ```javascript const MysqlPool = require('./mysql-pool'); const config = { host: 'localhost', user: 'root', password: '123456', database: 'test', waitForConnections: true, connectionLimit: 10, queueLimit: 0, }; const pool = new MysqlPool(config); async function getUsers() { const sql = 'SELECT * FROM users'; const result = await pool.execute(sql); return result; } getUsers().then((result) => { console.log(result); }).catch((err) => { console.error(err); }); ``` 上面的代码中,我们首先创建了一个 `config` 对象,包含了数据库连接的配置信息。然后实例化了一个 `MysqlPool` 对象,并且调用了 `execute` 方法执行了一条 SQL 查询语句。最后输出查询结果或者错误信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值