2014-05-18 4 views
9

Existe-t-il un moyen de faire une déclaration $ ou dans une correspondance d'élément?

J'ai ceci:

opened: { 
    $elemMatch: { 
     closed: false 
     openingEvening: {$lte: currentTime}, 
     closingEvening: {$gte: currentTime}, 
    } 
} 

et voudrais ajouter openingMorning à l

Comment puis-je prolonger comme:

opened: { 
    $elemMatch: { 
     closed: false 
     {$or: [ 
      {openingEvening: {$lte: currentTime}, closingEvening: {$gte: currentTime},}, 
      {openingMorning: {$lte: currentTime}, closingMorning: {$gte: currentTime}} 
     ] 
     } 
    } 
} 

est quelque chose comme cela possible?

Répondre

13

Bien sûr, il est, juste éclaircir la syntaxe, mais vous aviez fondamentalement il:

{ 
    "opened": { 
     "$elemMatch": { 
      "closed": false, 
      "$or": [ 
       { 
        "openingEvening": { "$lte": currentTime }, 
        "closingEvening": { "$gte": currentTime } 
       }, 
       { 
        "openingMorning": { "$lte": currentTime }, 
        "closingMorning": { "$gte": currentTime } 
       } 

      ] 
     } 
    } 
} 

Et donné une idée de l'échantillon des données:

{ 
    "_id" : ObjectId("537969cee90c3db84958aa86"), 
    "opened" : [ 
      { 
        "closed" : false, 
        "openingEvening" : 17, 
        "closingEvening" : 22, 
        "openingMorning" : 11, 
        "closingMorning" : 14 
      } 
    ] 
} 
{ 
    "_id" : ObjectId("53796a47e90c3db84958aa87"), 
    "opened" : [ 
      { 
        "closed" : false, 
        "openingMorning" : 13, 
        "closingMorning" : 14 
      } 
    ] 
} 

Une heure de 12 serait correspond au premier document, mais pas au deuxième, mais la valeur 13 correspond aux deux.

En notant également que ceux-ci sont dans un tableau de sorte que compte tenu de votre objectif estimé, vous voulez probablement un champ "dayOfWeek" à inclure aussi