• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

147
Vistas
Find record in mongo $nin on array

I have a database (mongo) that stores posts and user separate. Within the posts schema I have an array. When a user marks a post as read, their user id is pushed into the array on the post schema. I'm then trying to display only the posts which their user id don't appear in the array.

Here is an example of my post structure.

{ "_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 }

I tried using the following:

const posts = await Post.find({ posthideuser: { $nin: [user_id] } });

Which hasn't worked.

My Application is node, express/ejs. I will be happy to provide more information if required. Thanks in advance!

over 3 years ago · Juan Pablo Isaza
2 Respuestas
Responde la pregunta

0

Your query seems to work as expected:

 db.collection.find({
  posthideuser: {
    $nin: [
    "test2"
    ]
  }
})

playground

over 3 years ago · Juan Pablo Isaza Denunciar

0

There was an issue with the structure as indicated.

await Post.findByIdAndUpdate(id, { $push: { posthideuser: [res.locals.user_id] } });

should be: await Post.findByIdAndUpdate(id, { $push: { posthideuser: res.locals.user_id } });

over 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda