ElasticSearch: создание запроса bool с помощью предложений OR AND - PullRequest
0 голосов
/ 24 апреля 2018

Я пытаюсь преобразовать SQL-запрос в его эквивалентный запросasticsearch (SQL-таблица и индекс ES похожи).Это комбинация И / ИЛИ.

У меня есть запрос SQL, такой что

SELECT DISTINCT N_ID 
FROM   MYTABLE 
WHERE  ( [C_ID] = 4 AND E_ID = 765) 
         OR ( C_ID = 6 AND E_ID = 642 ))

Это мой эквивалентный упругий запрос

GET  mytable_index/_search
{
    "query": {
        "bool": {
            "should": [{
                    "must": [{
                            "term": {
                                "C_ID": 4
                            }
                        }, {
                            "term": {
                                "E_ID": 765
                            }
                        }
                    ]
                }, {
                    "must": [{
                            "term": {
                                "C_ID": 6
                            }
                        }, {
                            "term": {
                                "E_ID": 642
                            }
                        }
                    ]
                }
            ]
        }
    }
}

Но я получаю следующее исключение:

 {
            "type": "parsing_exception",
            "reason": "[must] query malformed, no start_object after query name",
            "line": 5,
            "col": 14
  }

Ответы [ 2 ]

0 голосов
/ 24 апреля 2018
This problem will not simply  solve using query. For achiving the distinct values you  need aggregations.

Please refer to my query

{
    "query": {
        "bool": {
            "should": [{
                    "bool": {
                        "must": [{
                                "match": {
                                    "C_ID": 4
                                }
                            }, {
                                "match": {
                                    "I_ID": 765
                                }
                            }
                        ]
                    }
                }, {
                    "bool": {
                        "must": [{
                                "match": {
                                    "C_ID": 6
                                }
                            }, {
                                "match": {
                                    "I_ID": 642
                                }
                            }
                        ]
                    }
                }
            ]
        }
    },
    "size":0,
    "aggs": {
    "distinct_values": {
      "terms": {
        "field": "N_ID",
        "size": 1000
      }
    }
  }

}
0 голосов
/ 24 апреля 2018

Я пропустил еще одну оговорку по поводу bool внутри должен

GET  mytable_index/_search
{
    "query": {
        "bool": {
            "should": [{
                    "bool": {
                        "must": [{
                                "match": {
                                    "C_ID": 4
                                }
                            }, {
                                "match": {
                                    "I_ID": 765
                                }
                            }
                        ]
                    }
                }, {
                    "bool": {
                        "must": [{
                                "match": {
                                    "C_ID": 6
                                }
                            }, {
                                "match": {
                                    "I_ID": 642
                                }
                            }
                        ]
                    }
                }
            ]
        }
    }
}
...