Tengo una base de datos (mongo) que almacena publicaciones y usuarios por separado. Dentro del esquema de publicaciones tengo una matriz. Cuando un usuario marca una publicación como leída, su identificación de usuario se inserta en la matriz en el esquema de la publicación. Luego intento mostrar solo las publicaciones cuya identificación de usuario no aparece en la matriz.
Aquí hay un ejemplo de la estructura de mi publicación.
{ "_id" : ObjectId("620eb60406b710c3ba2250f1"), "icon" : "fas fa-bullhorn", "title" : "Test Post", "scope" : true, "postedby" : "System", "postbody" : "Testing only content", "postcolour" : "orange", "posteddate" : "17/02/2022", "posthideuser" : [ "6205612355b2676a978b172b", "6203e917055a3558ffeb9fca" ] "__v" : 0 }
Intenté usar lo siguiente:
const posts = await Post.find({ posthideuser: { $nin: [user_id] } });
Lo cual no ha funcionado.
Mi aplicación es nodo, express/ejs. Estaré encantado de proporcionar más información si es necesario. ¡Gracias por adelantado!
Su consulta parece funcionar como se esperaba:
db.collection.find({ posthideuser: { $nin: [ "test2" ] } })
Hubo un problema con la estructura como se indica.
await Post.findByIdAndUpdate(id, { $push: { posthideuser: [res.locals.user_id] } });
debería ser: await Post.findByIdAndUpdate(id, { $push: { posthideuser: res.locals.user_id } });