sql >> Databáze >  >> NoSQL >> MongoDB

vrátit chybu řešení ve funkci uzlu

Protože načteného uživatele nepředáváte správně do query.exec .

Musíte udělat:

var Users  = require('../models/users-model.js');

function usernametoid(id) {
    return new Promise( function (resolve, reject) {
        Users.findOne({ username : id }).then( function(user){
          //If you use lodash you can do _.isNull(user)
          if(user == null){
            return reject({error : 'User not found'});
          }

          user.exec(function(userdata, error) {
              if(userdata){
                return resolve(userdata);
              } 
              if(error){
                 return reject({error : 'Error while executing query'});
              }
           });
        });
    });
}

Opravdu nechápu, proč importujete Users Model takhle. Nemyslím si, že Node bude moci takto načíst.

A měli byste vyžadovat mongoose ve vašem server.js

K zachycení odmítnutí potřebujete následující kód:

UserFactory.userNameToId(id).then( function(response){
  if(response.error){
    console.log('error '+response.error);
  }
  if(response){
    console.log('Got response '+response);
  }
});



  1. MongoDB findOneAndUpdate()

  2. Provedení aktualizace na cestě '_id' by změnilo neměnné pole '_id'

  3. Získejte dokumenty s vnořenými objekty splňujícími podmínku počtu

  4. MongoDB není autorizován pro dotaz - kód 13