NodeJs使用Mysql模块实现事务处理实例

依赖模块:

1. MysqLhttps://github.com/felixge/node-mysql

rush:bash;"> npm install MysqL --save

2. async:https://github.com/caolan/async

rush:bash;"> npm install async --save

(ps: async模块可换成其它Promise模块如bluebird、q等)

因为Node.js的MysqL模块本身对于事务的封装过于简单,而且直接使用会有很严重callback hell,故我们封装了两个方法一个用来初始化sql & params,一个用来执行事务。

初始化sql & params:

rush:js;"> function _getNewsqlParamEntity(sql,params,callback) { if (callback) { return callback(null,{ sql: sql,params: params }); } return { sql: sql,params: params }; }

如果你要执行多条sql语句,则需要:

rush:js;"> var sqlParamsEntity = []; var sql1 = "insert table set a=?,b=? where 1=1"; var param1 = {a:1,b:2}; sqlParamsEntity.push(_getNewsqlParamEntity(sql1,param1));

var sql2 = "update ...";
sqlParamsEntity.push(_getNewsqlParamEntity(sql1,[]));

//...更多要事务执行的sql

然后我在我自己的dbHelper.js里封装了execTrans的函数,用来执行事务

rush:js;"> var MysqL = require('MysqL'); var async = require("async");

module.exports = {
execTrans: execTrans,}

var pool = MysqL.createPool({
host: "MysqL host",user: "MysqL login user",password: "MysqL login pwd",database: "target db name",connectionLimit: 10,port: "MysqL db port",waitForConnections: false
});

function execTrans(sqlparamsEntities,callback) {
pool.getConnection(function (err,connection) {
if (err) {
return callback(err,null);
}
connection.beginTransaction(function (err) {
if (err) {
return callback(err,null);
}
console.log("开始执行transaction,共执行" + sqlparamsEntities.length + "条数据");
var funcAry = [];
sqlparamsEntities.forEach(function (sql_param) {
var temp = function (cb) {
var sql = sql_param.sql;
var param = sql_param.params;
connection.query(sql,param,function (tErr,rows,fields) {
if (tErr) {
connection.rollback(function () {
console.log("事务失败," + sql_param + ",ERROR:" + tErr);
throw tErr;
});
} else {
return cb(null,'ok');
}
})
};
funcAry.push(temp);
});

  async.series(funcAry,function (err,result) {
    console.log("transaction error: " + err);
    if (err) {
      connection.rollback(function (err) {
        console.log("transaction error: " + err);
        connection.release();
        return callback(err,null);
      });
    } else {
      connection.commit(function (err,info) {
        console.log("transaction info: " + JSON.stringify(info));
        if (err) {
          console.log("执行事务失败," + err);
          connection.rollback(function (err) {
            console.log("transaction error: " + err);
            connection.release();
            return callback(err,null);
          });
        } else {
          connection.release();
          return callback(null,info);
        }
      })
    }
  })
});

});
}

这样就可以执行事务了:

rush:js;"> execTrans(sqlParamsEntity,function(err,info){ if(err){ console.error("事务执行失败"); }else{ console.log("done."); } })

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...