ホームページ > ウェブフロントエンド > jsチュートリアル > NodeJs が Mysql モジュールを使用してトランザクション処理を実装する方法に関するケース コードの詳細な紹介

NodeJs が Mysql モジュールを使用してトランザクション処理を実装する方法に関するケース コードの詳細な紹介

黄舟
リリース: 2017-06-01 10:10:40
オリジナル
1191 人が閲覧しました

この記事では、Mysqlモジュールを使ってトランザクション処理を実装するNodeJsを主に紹介していますが、編集者がとても良いと思ったので、参考として共有させていただきます。エディターをフォローして一緒に見てみましょう

依存モジュール:

1. mysql

npm install mysql --save
ログイン後にコピー

2. async

npm install async --save
ログイン後にコピー

(追記: async モジュールは、bluebird、q、などの他のPromise モジュールで置き換えることができます)

Node.jsのmysqlモジュール自体が単純すぎてトランザクションをカプセル化できず、直接使用すると深刻なコールバック地獄を引き起こすため、SQLとparamsの初期化用とトランザクション実行用の2つのメソッドをカプセル化しました。 。

SQL とパラメータの初期化:

function _getNewSqlParamEntity(sql, params, callback) {
  if (callback) {
    return callback(null, {
      sql: sql,
      params: params
    });
  }
  return {
    sql: sql,
    params: params
  };
}
ログイン後にコピー

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

//...更多要事务执行的sql
ログイン後にコピー

次に、トランザクションを実行するために、execTrans 関数 を独自の dbHelper.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);
            }
          })
        }
      })
    });
  });
}
ログイン後にコピー

このようにして、実行できますトランザクション:

execTrans(sqlParamsEntity, function(err, info){
if(err){
  console.error("事务执行失败");
}else{
  console.log("done.");
}
})
ログイン後にコピー

以上がNodeJs が Mysql モジュールを使用してトランザクション処理を実装する方法に関するケース コードの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート