2015-03-31 228 views
3
我有很多在Elasticsearch嵌套类型的映射问题

不,我已经跑这来创建我的索引:Elasticsearch:下路[消息]嵌套的对象是嵌套类型

curl -XPOST 'http://localhost:9200/thread_and_messages' -d 
'{"mappings" : { 
    "message": { 
     "properties": { 
      "messages": { 
       "type": "nested", 
       "include_in_parent": true, 
       "properties": { 
        "message_id": {"type": "string"}, 
        "message_text": {"type": "string"}, 
        "message_nick": {"type": "string"} 
       } 
      } 
     } 
    } 
}}' 

那么这如何我已经索引的文档:

curl -XPUT 'http://localhost:9200/thread_and_messages/thread/1' -d 
'{ 
    "thread_id":"2", 
    "thread_name":"Windows", 
    "created":"Wed Mar 25 2015", 
    "first_nick":"Admin", 
    "messages":[ 
     {"message_id":"5", "message_text":" Pc with a mouse", "message_nick":"Admin"}, 
     {"message_id":"6", "message_text":"Keyboard", "message_nick":"Admin"}, 
     {"message_id":"7", "message_text":"iPhone", "message_nick":"Admin"}, 
     {"message_id":"8", "message_text":"Gym", "message_nick":"Admin"}]" 
}' 

这是我的查询:

curl -XGET 'http://localhost:9200/thread_and_messages/thread/_search' -d 
'{"query": { 
    "bool": { 
     "must": [ 
      {"match": {"thread_name": "windows"}}, 
      {"nested": { 
       "path": "messages", "query": { 
       "bool": { 
        "must": [{ 
         "match": {"messages.message_text": "gym"} 
        }] 
       } 
       } 
      }} 
     ]} 
    } 
}' 

我收到此错误,即使我已经清楚地映​​射消息为嵌套类型:

QueryParsingException[[thread_and_messages] [nested] nested object under path [messages] is not of nested type 

回答

5

这是因为你定义的映射类型"message",但随后索引你的文档类型"thread"。所以"thread"类型是动态创建的,但不是嵌套的子类型。我跑了作为张贴你的代码,然后看着映射:

GET /test_index/_mapping 
... 
{ 
    "test_index": { 
     "mappings": { 
     "message": { 
      "properties": { 
       "messages": { 
        "type": "nested", 
        "include_in_parent": true, 
        "properties": { 
        "message_id": { 
         "type": "string" 
        }, 
        "message_nick": { 
         "type": "string" 
        }, 
        "message_text": { 
         "type": "string" 
        } 
        } 
       } 
      } 
     }, 
     "thread": { 
      "properties": { 
       "created": { 
        "type": "string" 
       }, 
       "first_nick": { 
        "type": "string" 
       }, 
       "messages": { 
        "properties": { 
        "message_id": { 
         "type": "string" 
        }, 
        "message_nick": { 
         "type": "string" 
        }, 
        "message_text": { 
         "type": "string" 
        } 
        } 
       }, 
       "thread_id": { 
        "type": "string" 
       }, 
       "thread_name": { 
        "type": "string" 
       } 
      } 
     } 
     } 
    } 
} 

当我在映射改变"message""thread",并开始了,您的查询工作的罚款。

这里是我用来测试它的代码:

http://sense.qbox.io/gist/8a06b7849cf49006afd464ed4ee5b4e770759d5a