2016-08-29 6 views
0

上のネストされたオブジェクトのフィールドに検索:私はES 1.7.3でこのマッピングを持ってelasticsearch

{ 
    "customer": { 
     "aliases": {}, 
     "mappings": { 
     "customer": { 
      "properties": { 
       "addresses": { 
        "type": "nested", 
        "include_in_parent": true, 
        "properties": { 
        "address1": { 
         "type": "string" 
        }, 
        "address2": { 
         "type": "string" 
        }, 
        "address3": { 
         "type": "string" 
        }, 
        "country": { 
         "type": "string" 
        }, 
        "latitude": { 
         "type": "double", 
         "index": "not_analyzed" 
        }, 
        "longitude": { 
         "type": "double", 
         "index": "not_analyzed" 
        }, 
        "postcode": { 
         "type": "string" 
        }, 
        "state": { 
         "type": "string" 
        }, 
        "town": { 
         "type": "string" 
        }, 
        "unit": { 
         "type": "string" 
        } 
        } 
       }, 
       "companyNumber": { 
        "type": "string" 
       }, 
       "id": { 
        "type": "string", 
        "index": "not_analyzed" 
       }, 
       "name": { 
        "type": "string" 
       }, 
       "status": { 
        "type": "string" 
       }, 
       "timeCreated": { 
        "type": "date", 
        "format": "dateOptionalTime" 
       }, 
       "timeUpdated": { 
        "type": "date", 
        "format": "dateOptionalTime" 
       } 
      } 
     } 
     }, 
     "settings": { 
     "index": { 
      "refresh_interval": "1s", 
      "number_of_shards": "5", 
      "creation_date": "1472372294516", 
      "store": { 
       "type": "fs" 
      }, 
      "uuid": "RxJdXvPWSXGpKz8pdcF91Q", 
      "version": { 
       "created": "1050299" 
      }, 
      "number_of_replicas": "1" 
     } 
     }, 
     "warmers": {} 
    } 
} 

春のアプリケーションは、このクエリを生成します。「のアドレスに

{ 
    "query": { 
     "bool": { 
     "should": { 
      "query_string": { 
       "query": "(addresses.\\*:sample* AND NOT status:ARCHIVED)", 
       "fields": [ 
        "type", 
        "name", 
        "companyNumber", 
        "status", 
        "addresses.unit", 
        "addresses.address1", 
        "addresses.address2", 
        "addresses.address3", 
        "addresses.town", 
        "addresses.state", 
        "addresses.postcode", 
        "addresses.country" 
       ], 
       "default_operator": "or", 
       "analyze_wildcard": true 
      } 
     } 
     } 
    } 
} 

*。 :サンプル* "が唯一の入力です。

"query": "(sample* AND NOT status:ARCHIVED)" 

上記のコードは機能しますが、カスタマーオブジェクトのすべてのフィールドを検索します。 私は私が使用のアドレスフィールドに検索したいので、「アドレスを。*」

クエリはアドレスオブジェクトのフィールドは、文字列型のものであり、私は経度緯度フィールドを追加する前に場合にのみ機能しますアドレスオブジェクト上のdouble型のこれらの2つの新しいフィールドのため、エラーが発生しました。

エラー:

Parse Failure [Failed to parse source [{ 
    "query": { 
    "bool": { 
     "should": { 
      "query_string": { 
       "query": "(addresses.\\*:sample* AND NOT status:ARCHIVED)", 
        "fields": [ 
         "type", 
         "name", 
         "companyNumber","country", 
         "state", 
         "status", 
         "addresses.unit", 
         "addresses.address1", 
         "addresses.address2", 
         "addresses.address3", 
         "addresses.town", 
         "addresses.state", 
         "addresses.postcode", 
         "addresses.country", 
        ], 
        "default_operator": "or", 
        "analyze_wildcard": true 
       } 
      } 
     } 
    } 
    } 
]] 

NumberFormatException[For input string: "sample" 

アドレスを使用して、ネストされたオブジェクト内の "文字列" フィールドを検索する方法はあります*のみ。?

答えて

関連する問題