如何处理交易错误?

时间:2015-05-05 12:32:36

标签: javascript mysql node.js node-mysql

想象一下,我在HTTP请求处理程序中有以下代码:

// these come from the HTTP request payload.
var channel = {};
var screencast ={};

try {
  connection.beginTransaction(function(err) {
    if (err) { 
      throw err; 
    }
    connection.query('INSERT INTO Channels SET ?', channel, function (err, result) {
      if (err) { 
        connection.rollback(function() {
          throw err;
        });
      }
      connection.query('INSERT INTO Screencasts SET ?', screencast, function (err, result) {
        if (err) { 
          connection.rollback(function() {
            throw err;
          });
        }
        connection.commit(function(err) {
          if (err) { 
            connection.rollback(function() {
              throw err;
            });
          }
          console.log('success!');
        });
      });
    });
  });
} catch (err) {
  // render error page or something like that.
  console.log(err)
}

当发生错误时,我希望调用catch块 - 事实并非如此。 为什么不呢?

如果我不能catch他们,我没有看到抛出这么多错误的意义。有人可以解释一下吗?

另外,如果我不能依赖catch块,如何检测到错误发生,然后执行某事

(我对这段代码知之甚少,因为我改编了example。)

2 个答案:

答案 0 :(得分:0)

花了一些时间了解承诺

var mysql   = require('mysql');
var Promise = require('bluebird');
Promise.promisifyAll(require('mysql/lib/Connection').prototype);

connection.beginTransactionAsync().then(function() {
  return connection.queryAsync('INSERT INTO Channels SET ?', channel);
}).then(function() {
  return connection.queryAsync('INSERT INTO Screencasts1 SET ?', screencast);
}).then(function() {
  return connection.commit();
}).error(function(e) {
  connection.rollback();
});

答案 1 :(得分:0)

当您处理错误优先的异步回调时,不会抛出错误。而错误则作为回调函数的第一个参数传递。所以处理那里的错误。 (在嵌套回调的情况下,这可能意味着只是用错误调用父回调。)

基本上:你不能在这些回调中抛出错误,除非它们被引发到抛出它的同一个回调中。