nodejs连接mysql数据库支持事物封装-mysql模块

58 篇文章 16 订阅
57 篇文章 34 订阅

-- 安装模块

-- 封装代码

mysql.js
/*
nodejs连接mysql数据库支持事物封装
2016年7月26日14:47:06
QQ: 452076103 意外金喜
 */
var db    = {};
var mysql = require('mysql');
var pool  = mysql.createPool({
  connectionLimit : 10,
  host            : 'localhost',
  user            : 'root',
  password        : '123456',
  database        : 'nodejs'
});

//获取连接
db.getConnection = function(callback){
	pool.getConnection(function(err, connection) {
		if (err) {
			callback(null);
			return;
		}
		callback(connection);
	});
} 
module.exports = db;

-- 测试-无错误

var db = require('./mysql.js');
  var async = require('async');
  db.getConnection(function(connection){
    connection.beginTransaction(function(err) {
      if (err) { 
        console.log(err);
        return;
      }

      var task1 = function(callback){
        connection.query(`insert into user (name) values('a')`, function(err, result) {
          if (err) {
            console.log(err);
            callback(err,null);
            return;
          }
          console.log('第一次插入成功!');
          callback(null,result);
        })
      }
      var task2 = function(callback){
        connection.query(`insert into user (name) values('b')`, function(err, result) {
          if (err) {
            console.log(err);
            callback(err,null);
            return;
          }
          console.log('第二次插入成功!');
          callback(null,result);
        })
      }
      var task3 = function(callback){
        connection.query(`insert into user (name) values('c')`, function(err, result) {
          if (err) {
            console.log(err);
            callback(err,null);
            return;
          }
          console.log('第三次插入成功!');
          callback(null,result);
        })
      }

      async.series([task1, task2, task3],function(err,result){
        if (err) {
          console.log(err);
          //回滚
          connection.rollback(function() {
            console.log('出现错误,回滚!');
            //释放资源
            connection.release();
          });
          return;
        }
        //提交
        connection.commit(function(err) {
          if (err) {
            console.log(err);
            return;
          }
            
          console.log('成功,提交!');
          //释放资源
          connection.release();
        });
      })
    });
  })


运行结果:
数据库:

-- 发生错误

1.sql语句错误

比如把第三条sql语句user改为user1.

数据库还是之前插入的那3条数据,没有新增.

2.非sql语句错误

比如在async.series回调函数的第一行加入代码 : var err = 1;
人为添加错误

数据库依然没有新增数据,证明这个事物控制还是很靠谱的,之前写过nodejs连接sqlserver数据库支持事物的封装,
和sqlserver不同的地方是 : 
sqlserver的事物在sql语句错误的时候会自动回滚,mysql的事物都需要手动回滚.
非sql错误的时候都一样,都必须手动回滚.
同样从begin方法开始,所有的程序错误都要手动处理,如果发生错误,而又没处理到,是不会回滚的.

以下是封装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、付费专栏及课程。

余额充值