javascript 查询mysql_javascript-Node.js中的MySQL问题-获取所有查询

您应该将回调传递到db.query中,或者返回promise而不是dist,因为db.query是一种异步方法,因此无法以同步方式调用异步方法.在过去,例如,我们将使用回调

exports.getList = function(db, conf, callback) {

db.query('', function (err, result) {

if(err) return callback(err);

callback(null, result);

});

}

getList(db,conf, function(err, result) {

console.log(result);

});

现在我想建议使用Promise.

exports.getList = function(db, conf) {

return new Promise(function(resolve, reject) {

db.query("SELECT id, title FROM animal a " + (conf.limit > 0 ? " LIMIT " + conf.limit : "" ), function(err, rows, fields) {

if(err) {

reject(err);

return;

}

var dict = [];

for(var key in rows) {

var row = rows[key];

//

dict.push({

'title' : 'Buster',

'animal' : 'Dog',

'age' : '12',

'photo' : 'https://placeholdit.imgix.net/~text?txtsize=24&txt=260×200&w=260&h=200'

});

});

resolve(dict);

});

}

getList(db,config).then(function(result) {

console.log(result);

}).catch(function(e) {

console.log(e);

});

例如,您还可以并行调用两个查询

Promise.all([getList1(db,config), getList2(db,config)]).then(function(result) {

console.log('result of getList1', result[0]);

console.log('result of getList2', result[1]);

});

并保证,您可以将es6生成器与co一起使用,以同步方式调用异步方法

var co = require('co');

co(function* () {

try {

var result = yield getList(db, conf);

// here is your result

} catch(e) {

console.log(e);

}

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值