nodejs怎么同步从一个数据库查询函数中返回一个值?

我想把从数据库中查询得到的值储存到一个变量中然后打印出来,但数据库查询是异步的,打印函数总是先一步调用,查询函数后一步调用,打印出来的值是空的。下面是代码。
varsqlite3=require('sqlite3').verbose();
varasync=require('async');
varstr="";
vardb=newsqlite3.Database('score.db',function(){
db.all("select*fromscore",function(err,res){
if(!err){
//console.log(JSON.stringify(res));
str=JSON.stringify(res);
console.log(str);//@1这里输出的是有值的str
}else{
console.log(err);
}
});
});
console.log(str+"jjjj");//@2这里输出的Str,是没有值的空的
下面是输出结果:
jjjj这是@2console打印的,Str是空的
[{"id":1,"name":"jim","score":"100"},{"id":2,"name":"tom","score":"200"}]
这是@1console打印的,str是有值的。
请问怎样让查询回调先执行,让str获得值,传递出来,然后再执行最后一句@2的打印语句。javascript的异步回调真令人头痛啊,一直不知道怎么解决。
qq_遁去的一_1
浏览 310回答 2
2回答

四季花海

恭喜进入callback大坑varsqlite3=require('sqlite3').verbose();varasync=require('async');varstr="";varget_result=function(callback){vardb=newsqlite3.Database('score.db',function(){db.all("select*fromscore",function(err,res){if(!err){callback(JSON.stringify(res));console.log(str);//@1这里输出的是有值的str}else{console.log(err);}});});}get_result(function(data){console.log(data)})
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript