繁体   English   中英

当 for 中有查询时如何返回异步 function 的值

[英]How to return a value of an async function when there's a query inside a for

我试图在 for 循环完成后返回一个值,for 循环位于异步 function 内。 在循环内部,有一个插入到数据库的查询。

function 工作正常,但是当我使用 postman 时,响应返回空(即使值已插入数据库)

以下是我如何称呼 function:

        insertarPracticas(turno_id,req.body.lista_codigos_practicas, queryInsertarPracticas)
        .then( result=> {
                 res.status(200).json({
                      "Practicas Agregadas": result
                    })
                 }
        )

这是 function:

async function insertarPracticas(turno_id, req, queryInsertarPracticas){
//practicasAgregadas="";
return new Promise((resolve, reject) => {
    for (let i=0; i< req.length; i++){ 
        connection.query(
            queryInsertarPracticas, [turno_id, req[i]],(error2, row2) => { 
                if (error2) {
                    console.log("Error al insertar turno detalle (prácticas): "+req[i] +" "+ error2);             
                    practicasNoAgregadas += req[i] + "-";                   
                }else{
                    console.log("Turnos detalle agregados "+req[i]);
                    practicasAgregadas += req[i] + "-"; 
                    console.log("practicas "+practicasAgregadas);
                }
        });
        console.log("en for "+practicasAgregadas);
    }
    resolve(practicasAgregadas)

    // Or of there was an error
    reject("error");
})

这里发生的事情是 function 不会等待连接查询结束,即使它向数据库插入值,在 Postman 上我得到第一个结果,它是空的:

在此处输入图像描述

但我确实在我的数据库中插入了值。

处理这个问题的正确方法是什么? 我尝试使用 map 而不是 for,现在我正在尝试使用 promise,但我不确定我是否正确使用它。

这是控制台,您可以在其中看到 console.log("en for" + practicasAgregadas) 返回空,但它应该有一些值。

在您的 map 之后,只需使用:

等待 Promise.all(yourArray);

我不知道您是如何构建连接文件的,但您应该将其更改为异步 function 并等待 connection.query

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM