Erro super clássico de iniciante sobre assincronismo :)
O que está acontecendo :
var name; // FIRST you declare the name variable
schema.findone({name : 'Bob'} , function(er , db){ // SECOND you launch a request to the DB
name = db; // FOURTH name is populated.
console.log(db);
});
console.log(name); // !! THIRD !! you log name - it's empty
O que você deveria fazer :
schema.findone({name : 'Bob'} , function(er , db){
doSomethingElse(db);
});
function doSomethingElse(name){
console.log(name); // It's defined.
}
Você nem deveria declarar uma variável global, pois é uma prática ruim. Assim que os dados estiverem disponíveis, passe-os para outra função e faça algo com eles. Assim você não polui seu escopo global.
Editar :Como você absolutamente deseja uma variável global por algum motivo, faça isso:
var name;
schema.findone({name : 'Bob'} , function(er , db){
name = db;
console.log(name); // works fine
doSomethingElse();
});
console.log(name); // name is empty here, because the DB request is still in progress at this stage
function doSomethingElse(){
console.log(name); // Tadaaaa! It's a global variable and is defined!
}