[Elasticsearch - The Definitive Guide] The match Query
Elastic/TheDefinitiveGuide 2015. 12. 10. 11:53Match Query 와 Term Query 가 어떻게 다른지 간단하게 정리하는 차원에서 기록 합니다.
원문링크)
https://www.elastic.co/guide/en/elasticsearch/guide/current/match-query.html
Match Query Flow)
1. Check the field type
2. Analyze the query string (term query 로 재실행 됩니다.)
3. Find matching docs
4. Score each doc
Term Query Flow)
1. Find matching docs
2. Score each doc
보시면 아시겠지만 match query 보다 term query가 수행 단계가 적습니다.
결국 match query 를 실행 하더라도 term query 로 query rewrite 되기 때문에 검색 서비스 개발 시 잘 판단해서 사용하시면 좋을 듯 합니다.
보통은 front end 에서 smart query 또는 query preprocessing 이라고 해서 query stirng 에 대한 1차 가공 후 실제 검색엔진으로 질의시에는 term query 형태로 사용을 많이 합니다.