0

次を使用して、monk の find メソッドによって返されたデータにアクセスしようとしています。

var collection = db.get('Workflow');
collection.find({},{},function(e,workflow){
    console.log(workflow);
    var req0 = workflow[0];  //Error here
    console.log(req0);
    console.log(req0, req.body.accountType);
});

最初の console.log(workflow) は、json 配列のように見えるレコード全体を正しく返します。ただし、アクセスしようとすると、次のエラーが表示されます。

TypeError: Cannot read property '0' of undefined
at Promise.<anonymous> (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\routes\index.js:68:38)
at Promise.<anonymous> (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mpromise\lib\promise.js:178:8)
at Promise.emit (events.js:117:20)
at Promise.emit (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mpromise\lib\promise.js:84:38)
at Promise.fulfill (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mpromise\lib\promise.js:97:20)
at Promise.resolve (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mpromise\lib\promise.js:126:15)
at C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mongoskin\node_modules\mongodb\lib\mongodb\cursor.js:163:16
at commandHandler (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mongoskin\node_modules\mongodb\lib\mongodb\cursor.js:709:16)
at C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mongoskin\node_modules\mongodb\lib\mongodb\db.js:1846:9
at Server.Base._callHandler (C:\Users\abchauhan\Desktop\Work\NodeLearning\HelloNode\node_modules\monk\node_modules\mongoskin\node_modules\mongodb\lib\mongodb\connection\base.js:445:41)
4

1 に答える 1

0

なぜなら、配列を返さないからです。最初のレコードのみが必要な場合は、「制限」を試してみませんか

var collection = db.get('Workflow');
collection.find({},{'limit':1},function(e,workflow){
    console.log(workflow);
    var req0 = workflow;
    console.log(req0);
});
于 2015-08-31T08:43:36.017 に答える