Mango search in Arrays

前端 未结 1 1619
星月不相逢
星月不相逢 2020-12-06 13:47

My document has a structure like this:

{
  \"Calibration\": {
    \"Presettings\": {
      \"Date\": [
        {
          \"Value\": \"2016-09-02 10:11\",
          


        
相关标签:
1条回答
  • 2020-12-06 14:02

    First, you need to create your index. I suggest that you create an index on the Calibration.Presettings.Date field.

    You can use the following JSON object to create it:

    {
      "index": {
        "fields": [
          "_id",
          "Calibration.Presettings.Date.[].Type"
        ]
      },
      "type": "json"
    }
    

    So the selector would be like this :

    {
      "selector": {
        "Calibration.Presettings.Date": {
          "$elemMatch": {
            "$and": [
              {
                "Type": "generated"
              },
              {
                "Value": {
                  "$gte": "2016-09-01"
                }
              }
            ]
          }
        }
      }
    }
    

    We execute the query on the field Calibration.Pressettings.Date which is an Array. Since it's an array, we have to use the $elemMatch operator.

    Then, we have a $and condition for the Value and the Type.

    The Type of the Date has to be generated. With can either use the $eq operator or simply use this simple syntax: {"field":"value"}.

    Finally, the Date`s Value must be greater or equal to X date. We can use the $gte operator.

    0 讨论(0)
提交回复
热议问题