Как использовать логический запрос с function_score в Elasticsearch?

У меня есть 3 типа данных [доктор, статья, место], которые я хочу сопоставить с их документами на основе логического запроса. но я хочу присвоить типу доктора повышение на 3, типу места повысить на 2, а статье повысить на 1. У меня есть поисковый запрос, который использует function_score и bool query для сопоставления документов. но проблема в том, что он выдает исключение, которое говорит No function with the name [bool] is registered.. Вот мой запрос:

GET /my_index/doctor,article,place/_search
{
    "query": {
        "function_score": {
            "bool": {
                "should":
                [
                    {
                      "common": {
                        "title": {
                            "query":"$q",
                            "cutoff_frequency": 0.001,
                            "low_freq_operator": "and"
                            }
                        }
                    },
                    {
                        "prefix": {
                            "title": "$q"
                            }

                    },
                    {
                        "match_phrase_prefix" : {
                            "title" : {
                                "query": "$q",
                                "slop":  10
                            }
                        }
                    }
                ]
            },
            "functions":[
                {
                    "filter":{
                        "type":{
                           "value":"doctor"
                        }
                    },
                    "weight":3
                },
                {
                    "filter":{
                        "type":{
                           "value":"place"
                        }
                    },
                    "weight":2
                },
                {
                    "filter":{
                        "type":{
                           "value":"article"
                        }
                    },
                    "weight":1
                }
            ],
            "score_mode":"first",
            "boost_mode":"multiply"
        }
    }
}

Спасибо за вашу помощь.

ИЗМЕНИТЬ :

ОШИБКА:

{
  "error": "SearchPhaseExecutionException[Failed to execute phase [query], all shards failed;
            shardFailures {[fWqkaeoLSva_QwhrYHnG3A][darmanjoo][0]:
            SearchParseException[[darmanjoo][0]: from[-1],size[-1]:
              Parse Failure [Failed to parse source [
                {
                  "query": {
                    "function_score": {
                      "query": {
                        "bool": {
                          "should": [
                            {
                              "common": {
                                "title": {
                                  "query": "دکتر",
                                  "cutoff_frequency": 0.001,
                                  "low_freq_operator": "and"
                                }
                              }
                            },
                            {
                              "prefix": {
                                "title": "دکتر"
                              }
                            },
                            {
                              "match_phrase_prefix": {
                                "title": {
                                  "query": "دکتر",
                                  "slop": 10
                                }
                              }
                            }
                          ]
                        }
                      },
                      "functions": [
                        {
                          "filter": {
                            "type": {
                              "value": "doctor"
                            }
                          },
                          "weight": 3
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "place"
                            }
                          },
                          "weight": 2
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "article"
                            }
                          },
                          "weight": 1
                        }
                      ],
                      "score_mode": "first",
                      "boost_mode": "multiply"
                    }
                  }
                }
              ]]];
            nested: QueryParsingException[[darmanjoo] No function with the name [weight] is registered.]; }{[fWqkaeoLSva_QwhrYHnG3A][darmanjoo][1]:
            SearchParseException[[darmanjoo][1]: from[-1],size[-1]:
              Parse Failure [Failed to parse source [
                {
                  "query": {
                    "function_score": {
                      "query": {
                        "bool": {
                          "should": [
                            {
                              "common": {
                                "title": {
                                  "query": "دکتر",
                                  "cutoff_frequency": 0.001,
                                  "low_freq_operator": "and"
                                }
                              }
                            },
                            {
                              "prefix": {
                                "title": "دکتر"
                              }
                            },
                            {
                              "match_phrase_prefix": {
                                "title": {
                                  "query": "دکتر",
                                  "slop": 10
                                }
                              }
                            }
                          ]
                        }
                      },
                      "functions": [
                        {
                          "filter": {
                            "type": {
                              "value": "doctor"
                            }
                          },
                          "weight": 3
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "place"
                            }
                          },
                          "weight": 2
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "article"
                            }
                          },
                          "weight": 1
                        }
                      ],
                      "score_mode": "first",
                      "boost_mode": "multiply"
                    }
                  }
                }
              ]]];
            nested: QueryParsingException[[darmanjoo] No function with the name [weight] is registered.]; }{[fWqkaeoLSva_QwhrYHnG3A][darmanjoo][4]:
            SearchParseException[[darmanjoo][4]: from[-1],size[-1]:
              Parse Failure [Failed to parse source [
                {
                  "query": {
                    "function_score": {
                      "query": {
                        "bool": {
                          "should": [
                            {
                              "common": {
                                "title": {
                                  "query": "دکتر",
                                  "cutoff_frequency": 0.001,
                                  "low_freq_operator": "and"
                                }
                              }
                            },
                            {
                              "prefix": {
                                "title": "دکتر"
                              }
                            },
                            {
                              "match_phrase_prefix": {
                                "title": {
                                  "query": "دکتر",
                                  "slop": 10
                                }
                              }
                            }
                          ]
                        }
                      },
                      "functions": [
                        {
                          "filter": {
                            "type": {
                              "value": "doctor"
                            }
                          },
                          "weight": 3
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "place"
                            }
                          },
                          "weight": 2
                        },
                        {
                          "filter": {
                            "type": {
                              "value": "article"
                            }
                          },
                          "weight": 1
                        }
                      ],
                      "score_mode": "first",
                      "boost_mode": "multiply"
                    }
                  }
                }
              ]]];
            nested: QueryParsingException[[darmanjoo] No function with the name [weight] is registered.]; }]",
  "status": 400
}

МОЙ ОТРЕДАКТИРОВАННЫЙ ЗАПРОС ПРЯМО СКОПИРОВАН ИЗ MARVEL SENSE:

GET /darmanjoo/doctor,article,place/_search
{
    "query": {
        "function_score": {
            "query": {
                "bool": {
                    "should": [
                        {
                            "common": {
                                "title": {
                                    "query": "$q",
                                    "cutoff_frequency": 0.001,
                                    "low_freq_operator": "and"
                                }
                            }
                        },
                        {
                            "prefix": {
                                "title": "$q"
                            }
                        },
                        {
                            "match_phrase_prefix": {
                                "title": {
                                    "query": "$q",
                                    "slop": 10
                                }
                            }
                        }
                    ]
                }
            },
            "functions": [
                {
                    "filter": {
                        "type": {
                            "value": "doctor"
                        }
                    },
                    "weight": 3
                },
                {
                    "filter": {
                        "type": {
                            "value": "place"
                        }
                    },
                    "weight": 2
                },
                {
                    "filter": {
                        "type": {
                            "value": "article"
                        }
                    },
                    "weight": 1
                }
            ],
            "score_mode": "first",
            "boost_mode": "multiply"
        }
    }
}

person Ramin    schedule 28.11.2014    source источник
comment
Я видел ваш первый пост (который в конце концов был удален) и до сих пор не понимаю, что вы пытаетесь сделать. Вероятно, вы видели синтаксис на веб-сайте es о function_score, и вас не должна удивлять ошибка, которую вы получаете. Что именно вы пытаетесь сделать со своими данными и этим запросом?   -  person Andrei Stefan    schedule 28.11.2014
comment
@AndreiStefan, я пытаюсь искать документы с логическим запросом, но с разным ускорением для типов документов.   -  person Ramin    schedule 28.11.2014
comment
Нет, поясните на реальных данных. У меня есть врачи, статьи и места, и я хочу...   -  person Andrei Stefan    schedule 28.11.2014
comment
@AndreiStefan, готово, взгляните еще раз.   -  person Ramin    schedule 28.11.2014
comment
И все эти три типа имеют поле title?   -  person Andrei Stefan    schedule 28.11.2014


Ответы (1)


Попробуй это:

GET /my_index/doctor,article,place/_search
{
  "query": {
    "function_score": {
      "query": {
        "bool": {
          "should": [
            {
              "common": {
                "title": {
                  "query": "$q",
                  "cutoff_frequency": 0.001,
                  "low_freq_operator": "and"
                }
              }
            },
            {
              "prefix": {
                "title": "$q"
              }
            },
            {
              "match_phrase_prefix": {
                "title": {
                  "query": "$q",
                  "slop": 10
                }
              }
            }
          ]
        }
      },
      "functions": [
        {
          "filter": {
            "type": {
              "value": "doctor"
            }
          },
          "boost_factor": 3
        },
        {
          "filter": {
            "type": {
              "value": "place"
            }
          },
          "boost_factor": 2
        },
        {
          "filter": {
            "type": {
              "value": "article"
            }
          },
          "boost_factor": 1
        }
      ],
      "score_mode": "first",
      "boost_mode": "multiply"
    }
  }
}
person Andrei Stefan    schedule 28.11.2014
comment
теперь он выдает другое исключение, которое говорит о вложенности: QueryParsingException[[my_index] Функция с именем [вес] не зарегистрирована.] - person Ramin; 28.11.2014
comment
Этот запрос работал для меня. Убедитесь, что вы правильно скопировали и вставили. - person Andrei Stefan; 28.11.2014
comment
Я трижды проверил свой запрос. спасибо за попытку, но выдает ошибку в разделе EDIT POST - person Ramin; 28.11.2014
comment
Какую версию ES вы используете? - person Andrei Stefan; 28.11.2014
comment
номер версии: 1.3.4 - person Ramin; 28.11.2014
comment
также я скопировал свой запрос прямо из Marvel Sense. - person Ramin; 28.11.2014
comment
вес был добавлен в 1.4.0. - person Andrei Stefan; 28.11.2014
comment
В версиях до 1.4.0.Beta1 называется boost_factor. Я обновил свой ответ. Попробуйте снова. - person Andrei Stefan; 28.11.2014
comment
Спасибо за вашу помощь :) - person Ramin; 28.11.2014