我正在尝试在NodeJS中使用MySQL。我的整个应用程序都是使用promises构建的,所以我也想宣传mysql
模块。
所以我有这个:
Promise = require('bluebird');
var mysql = Promise.promisifyAll(require('mysql'));
现在,根据他们的API,connect()
方法接受一个参数,在连接错误的情况下调用err
回调。我的问题是,这如何转化为承诺?
承诺是否会因错误而得到解决?它会被拒绝吗?我可能需要.catch()
吗?这有什么作用?
答案 0 :(得分:8)
如果方法是节点" errback"使用单个参数 - 它将在then
中没有参数的情况下解析,或者在传递给它的err
时被拒绝。在promisification的情况下,您可以使用.error
或Promise.OperationalError
使用catch来捕获它。
这是一个简单的方法:
function getConnection(){
var connection = mysql.createConnection({
host : 'localhost',
user : 'me',
password : 'secret'
});
return connection.connectAsync().return(connection); // <- note the second return
}
getConnection().then(function(db){
return db.queryAsync(....);
}).error(function(){
// could not connect, or query error
});
如果这是用于管理连接 - 我使用Promise.using
- 这是来自API的示例:
var mysql = require("mysql");
// uncomment if necessary
// var Promise = require("bluebird");
// Promise.promisifyAll(mysql);
// Promise.promisifyAll(require("mysql/lib/Connection").prototype);
// Promise.promisifyAll(require("mysql/lib/Pool").prototype);
var pool = mysql.createPool({
connectionLimit: 10,
host: 'example.org',
user: 'bob',
password: 'secret'
});
function getSqlConnection() {
return pool.getConnectionAsync().disposer(function(connection) {
try {
connection.release();
} catch(e) {};
});
}
module.exports = getSqlConnection;
可以让你这样做:
Promise.using(getSqlConnection(), function(conn){
// handle connection here, return a promise here, when that promise resolves
// the connection will be automatically returned to the pool.
});