nodejs-使用数据库连接池技术对MySQL数据库的封装

  • 为什么使用数据库连接池而不是用正常的连接?
    • 我用过直接连接,但是会出现断连现象。
    • 而数据库连接池就不会断连
  • 代码
/**
* @Author kjprime
* @description 数据库模块
*/
const mysql  = require('mysql');
/*  mysql.escape() 此方法可以防止sql注入,可以顺带了解一下*/
const config_mysql =  {
    database: 'database',
    host: '127.0.0.1',    
    port: '3306',
    user: 'root',
    password: 'root',
	acquireTimeout: 1500, // 连接超时时间 可以不写
	connectionLimit: 10, // 最大连接数 默认属性值为10. 可以不写
	waitForConnections: true, // 超过最大连接时排队 可以不写
	queueLimit: 0, // 排队最大数量(0 代表不做限制)  可以不写
	// 用于指定允许挂起的最大连接数,如果挂起的连接数超过该数值,就会立即抛出一个错误,默认属性值为0.代表不允许被挂起的最大连接数。
}

const pool = mysql.createPool(config_mysql)

/**
 * 对Mysql的封装
 * @param {string} sql sql语句
 * @returns promise对象
 */
const db = function(sql){
	return new Promise(function(resolve, reject){
		pool.getConnection(function(err, connection){
			if(err){
				console.info(err.message)
				reject(err)
			}
			connection.query(sql, function(err, result){
				// 当连接不需要使用且需要从连接池中移除的时候,我们可以使用destory方法,该方法使用如下所示:
				// connection.destory();
				connection.release()   // 释放某个连接
				if(err){
					console.info(err.message)
					reject(err)
				}
				console.log("数据库Promise对象生成成功")
				resolve(result)
			})
		})
	})
}
/**
 * 获取数据
 * @param {sql} sql sql语句
 */
async function obtainData(sql){
	const data = await db(sql)
	console.log(data)
}

obtainData('SHOW DATABASES;') // 数据库中有哪些表

友情链接:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值