Node router can't get data from Sequelize using async await









up vote
1
down vote

favorite












Using Sequelizefor the first time I'm trying this code in my Node router:



router.get('/get-users', async (req, res, next) => 
const data = await users.getAll()
console.log('users in router:', data);
res.send(data)
);


And this is the sequlize code:



const users = 
getAll ()
sequelize
.query('SELECT * FROM users', model: User )
.then(users =>
console.log('users in database:', users);
return users;
)

;


The log statement in Sequelize code is getting me the right data but the log statement in router gets undefined.



It's probably async await problem but can you help?










share|improve this question

























    up vote
    1
    down vote

    favorite












    Using Sequelizefor the first time I'm trying this code in my Node router:



    router.get('/get-users', async (req, res, next) => 
    const data = await users.getAll()
    console.log('users in router:', data);
    res.send(data)
    );


    And this is the sequlize code:



    const users = 
    getAll ()
    sequelize
    .query('SELECT * FROM users', model: User )
    .then(users =>
    console.log('users in database:', users);
    return users;
    )

    ;


    The log statement in Sequelize code is getting me the right data but the log statement in router gets undefined.



    It's probably async await problem but can you help?










    share|improve this question























      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      Using Sequelizefor the first time I'm trying this code in my Node router:



      router.get('/get-users', async (req, res, next) => 
      const data = await users.getAll()
      console.log('users in router:', data);
      res.send(data)
      );


      And this is the sequlize code:



      const users = 
      getAll ()
      sequelize
      .query('SELECT * FROM users', model: User )
      .then(users =>
      console.log('users in database:', users);
      return users;
      )

      ;


      The log statement in Sequelize code is getting me the right data but the log statement in router gets undefined.



      It's probably async await problem but can you help?










      share|improve this question













      Using Sequelizefor the first time I'm trying this code in my Node router:



      router.get('/get-users', async (req, res, next) => 
      const data = await users.getAll()
      console.log('users in router:', data);
      res.send(data)
      );


      And this is the sequlize code:



      const users = 
      getAll ()
      sequelize
      .query('SELECT * FROM users', model: User )
      .then(users =>
      console.log('users in database:', users);
      return users;
      )

      ;


      The log statement in Sequelize code is getting me the right data but the log statement in router gets undefined.



      It's probably async await problem but can you help?







      node.js asynchronous sequelize.js






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 9 at 14:08









      Lee Moe

      227




      227






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          1
          down vote



          accepted










          Try to return the promise in the getAll(). Await is just a wrapper for a then() call of a promise but since you are not returning a promise the await is not waiting for the promise.



           getAll () 
          return sequelize
          .query('SELECT * FROM users', model: User )
          .then(users =>
          console.log('users in database:', users);
          return users;
          )






          share|improve this answer




















          • It works! Thank you! Yes I forgot to the part of returning a promise.
            – Lee Moe
            Nov 9 at 14:25











          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













           

          draft saved


          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53227286%2fnode-router-cant-get-data-from-sequelize-using-async-await%23new-answer', 'question_page');

          );

          Post as a guest






























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          1
          down vote



          accepted










          Try to return the promise in the getAll(). Await is just a wrapper for a then() call of a promise but since you are not returning a promise the await is not waiting for the promise.



           getAll () 
          return sequelize
          .query('SELECT * FROM users', model: User )
          .then(users =>
          console.log('users in database:', users);
          return users;
          )






          share|improve this answer




















          • It works! Thank you! Yes I forgot to the part of returning a promise.
            – Lee Moe
            Nov 9 at 14:25















          up vote
          1
          down vote



          accepted










          Try to return the promise in the getAll(). Await is just a wrapper for a then() call of a promise but since you are not returning a promise the await is not waiting for the promise.



           getAll () 
          return sequelize
          .query('SELECT * FROM users', model: User )
          .then(users =>
          console.log('users in database:', users);
          return users;
          )






          share|improve this answer




















          • It works! Thank you! Yes I forgot to the part of returning a promise.
            – Lee Moe
            Nov 9 at 14:25













          up vote
          1
          down vote



          accepted







          up vote
          1
          down vote



          accepted






          Try to return the promise in the getAll(). Await is just a wrapper for a then() call of a promise but since you are not returning a promise the await is not waiting for the promise.



           getAll () 
          return sequelize
          .query('SELECT * FROM users', model: User )
          .then(users =>
          console.log('users in database:', users);
          return users;
          )






          share|improve this answer












          Try to return the promise in the getAll(). Await is just a wrapper for a then() call of a promise but since you are not returning a promise the await is not waiting for the promise.



           getAll () 
          return sequelize
          .query('SELECT * FROM users', model: User )
          .then(users =>
          console.log('users in database:', users);
          return users;
          )







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 9 at 14:17









          RetBack

          411




          411











          • It works! Thank you! Yes I forgot to the part of returning a promise.
            – Lee Moe
            Nov 9 at 14:25

















          • It works! Thank you! Yes I forgot to the part of returning a promise.
            – Lee Moe
            Nov 9 at 14:25
















          It works! Thank you! Yes I forgot to the part of returning a promise.
          – Lee Moe
          Nov 9 at 14:25





          It works! Thank you! Yes I forgot to the part of returning a promise.
          – Lee Moe
          Nov 9 at 14:25


















           

          draft saved


          draft discarded















































           


          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53227286%2fnode-router-cant-get-data-from-sequelize-using-async-await%23new-answer', 'question_page');

          );

          Post as a guest














































































          Popular posts from this blog

          Kleinkühnau

          Makov (Slowakei)

          Deutsches Schauspielhaus