等待节点,js中的mysl查询执行

我在node.js中使用mysql。并且其中有一个嵌套查询。但是它不等待内部查询完成。我不知道回调和其他功能。我的代码就像。

exports._getItems=function(req,res){
    let categoryId=req.query.categoryPost;
    console.log(categoryId+"re")
    con.query("SELECT item_id FROM shop_products where category_id =?",[categoryId],function (err,result,fields) {
        if (err) throw res.status(403);
        else
        {   
            console.log("jhcsdcshd");
            var parsedResult = JSON.parse(JSON.stringify(result));
            let itemsData="";
            for (var i = 0; i < parsedResult.length; i++)
            {
                let item_id=parsedResult[i].item_id;
                console.log("Item_id is"+item_id)
                con.query("SELECT id,modelNo FROM items where id =?",[item_id],function  async(err1,result1,fields1,callback) {
                    if (err1) throw res.status(403);
                    else
                    { 
                        var parsedResult1=JSON.parse(JSON.stringify(result1));
                        console.log(parsedResult1)
                        itemsData=itemsData+parsedResult1[0].id;
                        console.log("dddd"+itemsData);
                        if(i=parsedResult.length)
                        {
                            console.log("here");
                            console.log("Data"+itemsData)
                            res.status(200).send(itemsData);
                        }
                    }
                });
                console.log("ppppppp"+itemsData);

            }

        }
    });
}

我只是想让任何人都可以告诉我,根据我的代码,我该如何确切地等待内部查询执行。非常感谢任何人能帮助我。谢谢

jackychen101211 回答:等待节点,js中的mysl查询执行

您不能在for循环内调用mysql查询,而必须等待执行。这是您的解决方案

<html>

<head>
  <style>
    .grid-container {
      display: grid;
      grid-template-columns: 4fr 2em 2fr;
      grid-template-areas: "main . side";
    }
    
    .grid-main {
      grid-area: main;
    }
    
    .grid-side {
      grid-area: side;
    }
    
    .flex-container {
      flex-direction: column;
    }
  </style>
</head>

<body>
  <div class="flex-container">
    <div class="grid-container">
      <div class="grid-main">
        <p>Lorem ipsum dolor sit amet,consectetur adipiscing elit,sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure
          dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident,sunt in culpa qui officia deserunt mollit anim id est laborum.</p>

        <p>Curabitur pretium tincidunt lacus. Nulla gravida orci a odio. Nullam varius,turpis et commodo pharetra,est eros bibendum elit,nec luctus magna felis sollicitudin mauris. Integer in mauris eu nibh euismod gravida. Duis ac tellus et risus vulputate
          vehicula. Donec lobortis risus a elit. Etiam tempor. Ut ullamcorper,ligula eu tempor congue,eros est euismod turpis,id tincidunt sapien risus a quam. Maecenas fermentum consequat mi.</p>
      </div>
    </div>
    <div class="grid-container">
      <div class="grid-main">
        <mark>Donec fermentum.</mark>
      </div>
      <div class="grid-side">This is a side note. It is lined up with the marked text. However,the initial text composition has been broken,due to the introduction of new div tags. 
      </div>
    </div>
    <div class="grid-container">
      <div class="grid-main">
        <p>Pellentesque malesuada nulla a mi. Duis sapien sem,aliquet nec,commodo eget,consequat quis,neque. Aliquam faucibus,elit ut dictum aliquet,felis nisl adipiscing sapien,sed malesuada diam lacus eget erat. Cras mollis scelerisque nunc. Nullam
          arcu. Aliquam consequat. Curabitur augue lorem,dapibus quis,laoreet et,pretium ac,nisi. Aenean magna nisl,mollis quis,molestie eu,feugiat in,orci. In hac habitasse platea dictumst.
        </p>
      </div>
    </div>
  </div>
</body>

</html>

}

<div class="carousel-item" style="background-color: #eff0f1">
        <div class="carousel-caption d-none d-md-block">
          <h2 class="display-4">First Slide</h2>
          <p class="lead">This is a description for the first slide.</p>
        </div>
      </div>

<style>
    .carousel-item {
        background-color: #eeeeee; /*Solid grey background*/
        }
    .carousel-caption {
        color: black;
        }
</style>

}

本文链接:https://www.f2er.com/3167804.html

大家都在问