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.
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, }
¿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, }, }, }