362 Stimmen

mongodb/mongoose findMany - findet alle Dokumente, deren IDs in einem Array aufgeführt sind

Ich habe ein Array von _ids und ich möchte alle Dokumente entsprechend zu erhalten, was ist der beste Weg, es zu tun?

Etwas wie ...

// doesn't work ... of course ...

model.find({
    '_id' : [
        '4ed3ede8844f0f351100000c',
        '4ed3f117a844e0471100000d', 
        '4ed3f18132f50c491100000e'
    ]
}, function(err, docs){
    console.log(docs);
});

Das Array kann Hunderte von _ids enthalten.

8voto

MD SHAYON Punkte 6992

Wenn Sie die async-await-Syntax verwenden, können Sie

const allPerformanceIds = ["id1", "id2", "id3"];
const findPerformances = await Performance.find({ 
    _id: { 
        $in: allPerformanceIds 
    } 
});

6voto

Nico Punkte 3677

Sowohl node.js als auch MongoChef zwingen mich dazu, in ObjectId zu konvertieren. Dies verwende ich, um eine Liste von Benutzern aus der DB zu holen und ein paar Eigenschaften abzurufen. Beachten Sie die Typkonvertierung in Zeile 8.

// this will complement the list with userName and userPhotoUrl 
// based on userId field in each item
augmentUserInfo = function(list, callback) {
    var userIds = [];
    var users = [];         // shortcut to find them faster afterwards

    for (l in list) {       // first build the search array
        var o = list[l];

        if (o.userId) {
            userIds.push(new mongoose.Types.ObjectId(o.userId)); // for Mongo query
            users[o.userId] = o; // to find the user quickly afterwards
        }
    }

    db.collection("users").find({
        _id: {
            $in: userIds
        }
    }).each(function(err, user) {
        if (err) {
            callback(err, list);
        } else {
            if (user && user._id) {
                users[user._id].userName = user.fName;
                users[user._id].userPhotoUrl = user.userPhotoUrl;
            } else { // end of list
                callback(null, list);
            }
        }
    });
}

4voto

Ich habe es wie unten beschrieben versucht und es funktioniert bei mir.

var array_ids = [1, 2, 6, 9]; // your array of ids

model.find({ 
    '_id': { 
        $in: array_ids 
    }
}).toArray(function(err, data) {
    if (err) {
        logger.winston.error(err);
    } else {
        console.log("data", data);
    }
});

-1voto

Tiny Bot Punkte 1

Ich verwende diese Abfrage, um die Dateien in Mongo GridFs zu finden. Ich wollte, um die durch seine Ids zu bekommen.

Für mich funktioniert diese Lösung: Ids type of ObjectId .

gfs.files
.find({ _id: mongoose.Types.ObjectId('618d1c8176b8df2f99f23ccb') })
.toArray((err, files) => {
  if (!files || files.length === 0) {
    return res.json('no file exist');
  }
  return res.json(files);
  next();
});

Das funktioniert nicht: Id type of string

gfs.files
.find({ _id: '618d1c8176b8df2f99f23ccb' })
.toArray((err, files) => {
  if (!files || files.length === 0) {
    return res.json('no file exist');
  }
  return res.json(files);
  next();
});

CodeJaeger.com

CodeJaeger ist eine Gemeinschaft für Programmierer, die täglich Hilfe erhalten..
Wir haben viele Inhalte, und Sie können auch Ihre eigenen Fragen stellen oder die Fragen anderer Leute lösen.

Powered by:

X