# 검색 요청 샘플 살펴보기
$ curl 'http://127.0.0.1:9200/books/_search?q=title:awesome&pretty'
### 결과
{
"took": 5, # 검색에 소요된 시간(ms)
"_shard": { # 샤드 정보
"total": 2,
"successful": 2,
"failed": 0
},
"hits": {
"total": 1, # 결과 개수
"max_score": 0.3708323, # 검색 결과 중 가장 높은 스코어
"hits": {} # 검색 결과 상세
}
}
🔍 GET /_all/_search?q=title:awesome
q
는 기본 검색 파라미터q
의 값으로 검색필드:검색어
를 전달🔍 GET /_all/_search?q=title:awesome&size=50
🔍 GET /books,videos/_search?q=title:awesome
🔍 GET /books/_search?q=title:awesome%20AND%20elastic
AND
또는 OR
로 구분OR
로 취급, 공백은
URL Encode
처리 필요 (%20)🔍 GET /books/_search?q=title:awesome&_source=false
🔍 GET /books/_search?q=title:awesome&fields=title,author
🔍 GET /books/_search?q=author:jonnung&sort=title:desc
sort
로 지정한 필드를 기준으로 정렬query context
query
파라미터를 전달하는 경우filter context
filter
파라미터를 사용하는 경우bool
쿼리 안에서 filter
나 must_not
파라미터를 사용하는 경우constant_score
쿼리나 filter
어그리게이션 안에서 filter
파라미터를 사용하는 경우형태소 분석이 적용된 컬럼의 값들은 형태소 분석기에 따라 토큰으로 분리되는데 이것을 텀(term) 이라 한다.
모든 대문자는 소문자로 변형되고, 중복된 단어는 삭제된다.
Term query는 주어진 질의문이 저장된 텀과 완전히 일치한 내용만 찾는다.
{
"query": {
"term": {
"title": "awesome"
}
}
}
2개 이상의 term을 같이 검색하려면 terms 쿼리를 이용한다.
필드의 값은 항상 배열로 전달해야 한다.
{
"query": {
"terms": {
"title": ["awsome", "elastic", "jonnung"],
"minium_should_match": 2
}
}
}
term 쿼리와 마찬가지로 질의어에 형태소 분석이 적용되지 않기 때문에 정확한 term값으로 검색해야 한다.
주어진 질의어로 term의 접두어를 검색하므로 term의 일부만으로도 검색할 수 있다.
{
"query": {
"prefix": {
"title": "awe"
}
}
}
비교할 수 있는 필드는 숫자 또는 날짜/시간 형식이어야 한다.
{
"query": {
"range": {
"pages": {"gte": 50, "lt": 150}
}
}
}
Term Query와 거의 동일하다. 색인된 term과 비교해서 일치하는 도큐먼트만 검색한다.
하지만 term query와 다른점은 주어진 질의문 자체를 형태소 분석을 거친 후 그 결과로 검색을 수행한다.
아래 질의문 결과는 이전 term의 예제와 동일한 결과가 나온다.
{
"query": {
"match": {
"title": "Awesome"
}
}
}
여러 검색어에 대한 조건식을 변경하려면 operator
을 사용한다.
{
"query": {
"match": {
"title": {
"query": "Awesome Elastic",
"operator": "and" # default 'and'
}
}
}
}
analyzer
를 지정해 검색 쿼리의 어떤 형태소 분석을 적용할지 결정할 수 있다.
{
"query": {
"match": {
"title": {
"query": "Awesome Elastic",
"analyzer": "whitespace"
}
}
}
}
여러 쿼리를 boolean 조건으로 결합해서 도큐먼트를 검색한다.
must
: 반드시 매칭되는 조건, score에 영향을 준다.filter
: must
와 동일한 동작하지만, score에 영향을 주지 않는다.should
: bool 쿼리가 query context에 있고 must
또는 filter
절이 있다면, should
쿼리와 일치하는 결과가 없더라도 매치가 된다. bool 쿼리가 filter context 안에 있거나, must
또는 filter
중에 하나라도 있는 경우에만 매칭된다. minimum_should_match
이 값을 지정해서 컨트롤할 수 있다.must_not
: 이 쿼리와 매칭되지 않아야 한다.{
"query": {
"bool": {
"must": {
"term": {"title": "the"}
},
"must_not": {
"term": {"contents": "world"}
},
"should": [
{"term": {"title": "awesome"}},
{"term": {"title": "elastic"}}
]
}
}
}