Heim >Web-Frontend >js-Tutorial >So verwenden Sie das automatische Transaktionsrecycling im MySQL-Verbindungspool (mit Code)

So verwenden Sie das automatische Transaktionsrecycling im MySQL-Verbindungspool (mit Code)

php中世界最好的语言
php中世界最好的语言Original
2018-04-12 17:53:452118Durchsuche

Dieses Mal zeige ich Ihnen, wie Sie das automatische Transaktionsrecycling im MySQL-Verbindungspool (mit Code) verwenden ist ein praktischer Fall.

Das Beispiel in diesem Artikel beschreibt, wie Node.js

den MySQL-Verbindungspool implementiert, um Verbindungen mithilfe von Transaktionen automatisch wiederzuverwenden. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!
var mysql = require('mysql'),
  Connection = require('mysql/lib/Connection.js');
var pool = mysql.createPool({
  host: '127.0.0.1',
  database: 'myDB',
  port: 3306,
  user: 'root',
  password: 'root',
  debug: false,
  connectionLimit: 3
});
var execPool = function() {
  pool.getConnection(function(err, conn) {
    transAutoRelease(conn);
    conn.beginTransaction(function(err) {
      if (err) throw err;
      conn.query("INSERT INTO test(id,name,date,test) values(1,'123',now(),1)",
        function(err, ret) {
          if (err) {
            console.error(err);
            conn.rollback(function() {});
          } else {
            console.log(ret);
            conn.query('UPDATE test set id=12321312 where id=1', function(err, ret) {
              if (err) {
                console.error(err);
                conn.rollback(function() {
                });
              } else {
                conn.commit(function() {
                  console.log('success' + JSON.stringify(ret));
                });
              }
            });
          }
        });
    });
  });
}
function after(fn, cb) { return function() {
    fn.apply(this, arguments);
    cb();
  }
}
function transAutoRelease(conn) {
  if (conn.commit == Connection.prototype.commit)
    conn.commit = after(conn.commit, release);
  if (conn.rollback == Connection.prototype.rollback)
    conn.rollback = after(conn.rollback, release);
  function release() {
    if (conn) {
      conn.release();
    }
  }
}
var intervalStartProcess = function() {
  setInterval(function() {
    execPool();
  }, 1000);
}
for (var i = 5 - 1; i >= 0; i--) {
  intervalStartProcess();
}

Empfohlene Lektüre:

Angepasste domänenübergreifende Ajax-Komponentenkapselung


Warum Node.js für die Entwicklung von Webanwendungen verwenden


Express+multer implementiert die spezifischen Schritte zum Hochladen von Knotenbildern


Das obige ist der detaillierte Inhalt vonSo verwenden Sie das automatische Transaktionsrecycling im MySQL-Verbindungspool (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn