nodejs查询数据库后,获取result结果集并赋值返回

本文介绍了如何在Node.js中正确获取并返回数据库查询的结果集。在处理过程中遇到问题,但通过特定的解决方式,成功实现了将查询数据赋值并传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nodejs获取了查询结果,但不能返回出去,

情形如下:

var query = function (path,id,param,sqlWhere,res){
    var aa = 111;
var sql = "select * from user"; var mysql = dbHelper.getMysql(); mysql.query({ sql: sql }, function (err, rows) { res.end(JSON.stringify(rows)); aa = rows; });
return aa;//返回结果是111而不是rows
};

解决方式

var query = function (path,id,param,sqlWhere,res){
    var promise = new Promise(function (resolve, reject) {
        
        var sql = getFileSql(path,id,param,sqlWhere);
        var mysql = dbHelper.getMysql();
        mysql.query({
          sql: sql
        }, function (err, rows) {
            res.end(JSON.stringify(rows));
            resolve(rows);//关键
        });    
    
    });
    promise.then(function (value) {
        console.log(value);
        return value;
    }, function (value) {});
    return promise;
};

完毕:

 

=====================================原文内容如下======================================

http://www.jianshu.com/p/6e77d6fdaf13

===================================================================================

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值