MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

TypeError:db.collection ist keine Funktion, CANNOT GET

Inkorrekte Syntax, Sie müssen die Eigenschaft von db.collection lesen, aber Sie rufen das auf. Beispiel:

db.collection['products']!!!


db.collection['text'].save({
        title: title,
        author: author,
        text: text
    }, callback);
};

module.exports.findBookByTitle = function (db, title, callback) {
    db.collection['text'].findOne({
        title: title
    }, function (err, doc) {
        if (err || !doc) callback(null);
        else callback(doc.text);
    });
};

module.exports.findProductsByName = function (db, name, callback) {
    db.collection['products'].findOne({

Zum Beispiel

var object ={'some_value':'value','some_methid':function(){ return 'method result'}}

Sie können die Eigenschaft 'some_value' lesen und setzen, zum Beispiel:

object['some_value'] // return 'value'
object.some_value // return 'value'

// SCHRITT 2

Ok, in Ihren Methoden von database.js übergeben Sie die db-Variable, aber das ist keine db-Instanz, es ist ein Mongoose-Modell, und Sie müssen so schreiben:

module.exports.findBookByTitle = function (model, title, callback) {
    model.findOne({
        title: title
    }, function (err, doc) {
        if (err || !doc) callback(null);
        else callback(doc.text);
    });
};

module.exports.findProductsByName = function (model, name, callback) {
    model.findOne({
        name: name
    }, function (err, doc) {
        if (err || !doc) callback(null);
        else callback(doc.products);
    });
};