• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

229
Views
Mongo-go-driver consulta anidada golang

Solía tener dos filtros para obtener datos de mi mongoDB, sin embargo, no creo que sea eficiente considerando que tiene que hacer dos consultas a la base de datos.

 filter = bson.M{ "$and": []bson.M{ {"partnerA.id": id}, {"unlocked": false}, {"deletedAt": nil}, }, }
 filter = bson.M{ "$and": []bson.M{ {"partnerB.id": id}, {"unlocked": false}, {"deletedAt": nil}, }, }

Traté de combinarlos usando esta solución que encontré y obtuve este filtro:

 filter := bson.M{ "$and": []bson.M{ {"partnerA.id": id}, {"unlocked": false}, {"deletedAt": nil}, }, "$or": bson.A{ bson.M{"$and": []bson.M{ {"partnerB.id": id}, {"unlocked": false}, {"deletedAt": nil}, }}, }, }

Sin embargo, no funciona y no puedo encontrar la solución para ello. ¿Alguien ve el problema de esto?

Gracias.

about 3 years ago · Santiago Trujillo
1 answers
Answer question

0

Supongo que está tratando de combinar esas dos consultas con el operador OR . Otra cosa, vi dos cláusulas similares entre los dos, es "unlocked": false y "deletedAt": nil .

Puede tener una consulta más corta como la siguiente:

 filter := bson.M{ "$or": []bson.M{ {"partnerA.id": id}, {"partnerB.id": id}, }, "unlocked": false, "deletedAt": nil, }

Actualización #1

¿Qué tal una nueva consulta donde solo devuelvo los valores si ((partnerA.id = id y partnerA.unlocked = true) o (partnerB.id = id y partnerB.unlocked = true)) Blockquote

 filter := bson.M{ "$or": []bson.M{ { "partnerA.id": id, "partnerA.unlocked": true, }, { "partnerB.id": id, "partnerB.unlocked": true, }, }, }
about 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error