明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

對(duì)于NodeJs如何使用Mysql模塊完成事務(wù)處理案例

[摘要]本篇文章主要介紹了NodeJs使用Mysql模塊實(shí)現(xiàn)事務(wù)處理 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧依賴模塊:1. mysqlnpm install mysql --save2. asyncnpm install async --save(ps: async模...
本篇文章主要介紹了NodeJs使用Mysql模塊實(shí)現(xiàn)事務(wù)處理 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

依賴模塊:

1. mysql

npm install mysql --save

2. async

npm install async --save

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

因?yàn)?a target="_blank">Node.js的mysql模塊本身對(duì)于事務(wù)的封裝過于簡(jiǎn)單,而且直接使用會(huì)有很嚴(yán)重callback hell,故我們封裝了兩個(gè)方法,一個(gè)用來初始化sql & params,一個(gè)用來執(zhí)行事務(wù)。

初始化sql & params:

function _getNewSqlParamEntity(sql, params, callback) {
  if (callback) {
    return callback(null, {
      sql: sql,
      params: params
    });
  }
  return {
    sql: sql,
    params: params
  };
}

如果你要執(zhí)行多條sql語句,則需要:

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, []));

//...更多要事務(wù)執(zhí)行的sql

然后我在我自己的dbHelper.js里封裝了execTrans的函數(shù),用來執(zhí)行事務(wù)

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("開始執(zhí)行transaction,共執(zhí)行" + sqlparamsEntities.length + "條數(shù)據(jù)");
      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("事務(wù)失敗," + 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("執(zhí)行事務(wù)失敗," + err);
              connection.rollback(function (err) {
                console.log("transaction error: " + err);
                connection.release();
                return callback(err, null);
              });
            } else {
              connection.release();
              return callback(null, info);
            }
          })
        }
      })
    });
  });
}

這樣就可以執(zhí)行事務(wù)了:

execTrans(sqlParamsEntity, function(err, info){
if(err){
  console.error("事務(wù)執(zhí)行失敗");
}else{
  console.log("done.");
}
})

以上就是關(guān)于NodeJs如何使用Mysql模塊實(shí)現(xiàn)事務(wù)處理實(shí)例的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識(shí)。