1
私はelasticSearchを使用しています。2.2 whithインデックス私は簡単にマッピングを変更することはできません。キーワードに基づいて検索リクエストを行いたいと思います。ここで配列文字列フィールドのElasticSearchスコアを変更しますか?
私の文字列配列フィールドのマッピング "キーワード":
"keywords": {
"type": "string",
"norms": {
"enabled": false
},
"analyzer": "analyzer_keyword"
"analyzer_keyword": {
"filter": "lowercase",
"tokenizer": "keyword"
}
私はPOSTでそれのようにブール要求を使用して、それを照会する:
{
"query":
{
"bool" : {
"should" :
[
{
"term":
{
"keywords": "foo bar",
}
},
{
"term":
{
"keywords": "baz",
}
},
{
"term":
{
"keywords": "qux",
}
}
]
}
},
"highlight": {
"fields" : {
"keywords" : {}
}
}
}
最高のヒットスコアが最大のキーワードを含むヒットであることを希望します。
ヒットの例ソートスコアによって私はこの要求に対して希望:
- {ID:#X、キーワード:[ "FOOバー"、 "バズ"]}
- {ID:#Zキーワード:[ "FOOバー"、 "qux"]}
- {ID:#Y、キーワード:[ "qux"]}
- {ID:#W、キーワード:[ "バズ"]}
代わりに、私はこのようないくつかの結果を得ました:
- {ID:#X、キーワード:[ "FOOバー"、 "バズ"]}
- {ID:#Y、キーワード:[ "qux"]}
- {ID:#Zキーワード:[ "fooのバー"、 "qux"]}
- {ID:#W、キーワード:[ "バズ"]}
は、あなたのアイデアは私がそれを管理するために助けることができる必要がありますか?
私の悪い英語と申し訳ありませんが、あなたの助けを借りて申し訳ありません。
ご回答ありがとうございます。 ブーストは私が思うこの場合私を助けることができません。キーワードの一致数でソートしたい –
確かに、私は質問を誤解していたし、あなたのクエリのタグのオフセットに応じて並べ替えると思った、私は私の答えを編集しました。今日はスコアリングシステムについて多くのことを学んだ。 – Pandawan
それははるかに良く機能しますが、私はいつもいくつかのエラーがあります。私はこの瞬間にこれを躊躇し、後者を試してみる。 あなたの答えをありがとう! –