Mongoose find(),如何访问结果文件?

时间:2013-04-06 14:21:36

标签: node.js mongodb express mongoose

我刚开始玩mongoose和mongo。我有以下代码:

var ninjaSchema = mongoose.Schema({
    name: String,
    skill: Number
});

var Ninja = mongoose.model('Ninja',ninjaSchema);

module.exports = {
init : function(){
    console.log('Connecting to database');
    mongoose.connect('mongodb://localhost/mydb');
    var db = mongoose.connection;
    db.on('error', console.error.bind(console, 'connection error:'));
    db.once('open', function callback () {
      console.log('Successfully connected!');
    });
},
createNinja : function(name,skill){
    var n = new Ninja({name:name,skill:skill});
    n.save(function(err,n){
        if (err)
            console.log('saving failed');
        console.log('saved '+ n.name);
    });
},
getNinjas : function(){
    var res = null;
    res = Ninja.findOne({},'name skill',function(err,docs){
        if (err)
            console.log('error occured in the query');
        return 'ninja name: '+docs.name+' ninja skill: '+docs.skill;
    });

    return res;
}

向数据库添加条目没有问题,但我在检索它们时遇到问题。我对整个事情的运作方式感到有些困惑。我的理解如下:

有一些模式,就像oop中的类一样,只是数据库中记录的蓝图。该模型是一个记录,好的,也许更多,因为我看到你可以添加一个方法到模型。嗯......我真的不明白如何使用它们。你能告诉我他们到底是什么意思吗?

回到主题:发出find命令时,它会调用匿名函数,而docs应该是正确的结果吗?现在我如何访问它们?从现在起如果我记录res我得到以下内容:

{ options: {},
safe: undefined,
_conditions: {},
_updateArg: {},
_fields: { name: 1, skill: 1 },
_geoComparison: undefined,
op: 'findOne',
model: 
{ [Function: model]
 base: 
  { connections: [Object],
    plugins: [],
    models: [Object],
    modelSchemas: [Object],
    options: {} },
 modelName: 'Ninja',
 model: [Function: model],
 db: 
  { base: [Object],
    collections: [Object],
    models: {},
    replica: false,
    hosts: null,
    host: 'localhost',
    port: 27017,
    user: undefined,
    pass: undefined,
    name: 'mydb',
    options: [Object],
    _readyState: 1,
    _closeCalled: false,
    _hasOpened: true,
    _listening: true,
    _events: [Object],
    db: [Object] },
 schema: 
  { paths: [Object],
    subpaths: {},
    virtuals: [Object],
    nested: {},
    inherits: {},
    callQueue: [],
    _indexes: [],
    methods: {},
    statics: {},
    tree: [Object],
    _requiredpaths: [],
    options: [Object],
    _events: {} },
 options: undefined,
 collection: 
  { collection: [Object],
    opts: [Object],
    name: 'ninjas',
    conn: [Object],
    queue: [],
    buffer: false } } }

另外,如果我使用Ninja.find(...,function(err,docs){ ... }),我该如何使用文档?或者我如何检索我的记录?

1 个答案:

答案 0 :(得分:17)

我发现了这个错误。它更像是一个概念性的:我正在处理异步调用,并试图从另一个函数返回结果,并且不知道它何时会执行。那么我发出的请求是执行db查询并返回结果,结果是null。这段代码:

getNinjas : function(){
    var res = null;
    Ninja.find({},'name skill',function(err,docs){
        if (err)
            console.log('error occured in the database');
        console.log(docs);
    });     
    return res;
}

返回null,但是! console.log(docs)向控制台输出数据库中的所有值,我试图做的。现在我需要进行更改,很可能会传递一个回调,该回调将在收到结果时执行。

通过更改,代码如下所示:

getNinjas : function(res){
    var twisted = function(res){
        return function(err, data){
            if (err){
                console.log('error occured');
                return;
            }
            res.send('My ninjas are:\n');
            console.log(data);
        }
    }

    Ninja.find({},'name skill',twisted(res));
}

所以这样我可以传递响应对象,这样我就可以发送我的忍者的名字了:)