2016-11-14 45 views
1

下面的查詢的目的是爲每個條件返回n個結果,即它必須匹配合作夥伴16並匹配'venueTown'或合作伙伴16並匹配'venueName'。目前它返回每個字段必須包含相同字符串的結果。在我的情況字段中:姓名,場地名稱和場地城鎮必須包含曼徹斯特,但我想爲每對{(partnersites,venueName),(partnersites,venueTown)}分開結果。ElasticSearch合併條件語句'和'與'或'

{ 
    "size": 0, 
    "_source": ["groupedName", "groupedDisplayName", "groupedUrl", "eventCode", "venueName", "venueTown", "venueId", "media"], 
    "query": { 
     "bool": { 
      "must": [{ 
       "match": { 
        "partnersites": { 
         "query": "16" 
        } 
       } 
      }, { 
       "match": { 
        "name": "manchester" 
       } 
      }, { 
       "match": { 
        "venueName": "manchester" 
       } 
      }, { 
       "match": { 
        "venueTown": "manchester" 
       } 
      }, { 
       "match": { 
        "venueTown": "manchester" 
       } 
      }] 
     } 
    }, 
    "aggs": { 
     "distinct_names": { 
      "terms": { 
       "field": "name.keyword", 
       "size": 10 
      }, 
      "aggs": { 
       "top_tag_hits": { 
        "top_hits": { 
         "size": 1, 
         "_source": ["groupedName", "groupedDisplayName", "groupedUrl", "eventCode", "venueName", "venueTown", "venueId", "media"] 
        } 
       } 
      } 
     }, 
     "distinct_venues": { 
      "terms": { 
       "field": "venueName.keyword", 
       "size": 10 
      }, 
      "aggs": { 
       "top_tag_hits": { 
        "top_hits": { 
         "size": 1, 
         "_source": ["groupedName", "groupedDisplayName", "groupedUrl", "eventCode", "venueName", "venueTown", "venueId", "media"] 
        } 
       } 
      } 
     }, 

     "distinct_towns": { 
      "terms": { 
       "field": "venueTown.keyword", 
       "size": 10 
      }, 
      "aggs": { 
       "top_tag_hits": { 
        "top_hits": { 
         "size": 1, 
         "_source": ["groupedName", "groupedDisplayName", "groupedUrl", "eventCode", "venueName", "venueTown", "venueId", "media"] 
        } 
       } 
      } 
     } 
    } 
} 

回答

1

試試這個:

{ 
    "size": 0, 
    "query": { 
    "bool": { 
     "must": [ 
     { 
      "bool": { 
      "should": [ 
       { 
       "bool": { 
        "must": [ 
        { 
         "term": { 
         "partnersites": "16" 
         } 
        }, 
        { 
         "match_phrase_prefix": { 
         "name": "mancheste" 
         } 
        } 
        ] 
       } 
       }, 
       { 
       "bool": { 
        "must": [ 
        { 
         "term": { 
         "partnersites": "16" 
         } 
        }, 
        { 
         "match_phrase_prefix": { 
         "venueName": "mancheste" 
         } 
        } 
        ] 
       } 
       }, 
       { 
       "bool": { 
        "must": [ 
        { 
         "term": { 
         "partnersites": "16" 
         } 
        }, 
        { 
         "match_phrase_prefix": { 
         "venueTown": "mancheste" 
         } 
        } 
        ] 
       } 
       } 
      ] 
      } 
     } 
     ] 
    } 
    }, 
    "aggs": { 
    "distinct_names": { 
     "terms": { 
     "field": "groupedName.keyword", 
     "size": 30 
     }, 
     "aggs": { 
     "top_tag_hits": { 
      "top_hits": { 
      "size": 1, 
      "_source": [ 
       "groupedName", 
       "groupedDisplayName", 
       "groupedUrl", 
       "eventCode", 
       "venueName", 
       "venueTown", 
       "venueId", 
       "media" 
      ] 
      } 
     } 
     } 
    } 
    } 
}