Je ne sais pas si vous cherchez toujours la réponse à cela, mais si vous utilisez la mangouste, vous pouvez profiter du remplir la fonctionnalité et l'utiliser comme middleware
Voici un exemple :Disons que je veux une liste de personnes et de leurs amis, et leurs amis-amis, etc. Le résultat devrait ressembler à ceci :
[
{
_id: "abc123",
name: "John Doe",
friends: [
{
_id: "efg456",
name: "Foo bar",
friends: [
{
_id: "hij789",
name: "Jane Doe",
friends: [more friends...]
}
]
}
]
]
Dans la base de données, ils sont stockés comme ceci
{_id: "abc123", name: "John Doe", friends: ["efg456"]}
{_id: "efg456", name: "Foo bar", friends: ["hij789"]}
{_id: "hij789", name: "Jane Doe", friends: [more friends...]}
Votre schéma et middleware seraient :
const Person = new Schema<Folder>({
name: {type: String, required: true},
friends: [{type: Schema.Types.ObjectId, ref: "person"}],
}, {timestamps: true})
Person.pre("find", function(next) {
this.populate("friends")
next()
})
Ajout de la fonction en tant que middleware à find
le fera fonctionner pour chaque personne trouvée. Cela inclut les enfants dans les friends
tableau.