ElasticSearch - Kombinácia Dotazy na 4 samostatné náhodne sourted skupiny?

0

Otázka

Som celkom nový elasticsearch (aj keď s reálna trochu SQL skúsenosti) a som v súčasnej dobe stretávajú s uvedením správneho dotaz spolu. Mám 2 boolean polia isPlayer a isEvil že zápis je buď true alebo false o. Na základe toho som si chcú rozdeliť moje datasetu do 4 skupín:

  1. isPlayer: pravda, isEvil: pravda
  2. isPlayer: pravda, isEvil: false
  3. isPlayer: false, isEvil: pravda
  4. isPlayer: false, isEvil: false

Tieto skupiny sa chcem náhodne zoradiť do seba, potom priložiť ich, aby sa jeden dlhý zoznam, ktorý som si paginate. Rád by som sa k tomu, že vo vnútri dotaz, ako sa zdá ako "správny" spôsob, ako to urobiť, pretože by som to podobne v SQL. V tomto zozname skupín majú byť zoradené v poradí, takže najprv všetky položky Skupiny 1 v náhodnom poradí, potom všetky položky Skupiny 2 v náhodnom poradí, potom všetky položky Skupiny 3, atď. . Je potrebné, aby náhodnosť triediaceho je reprodukovateľné, ak vzhľadom na rovnaké vstupy, takže ak triedenie je založené na random_score v ideálnom prípade by som byť pomocou osiva na náhodnosť.

Môžem stavať jeden dotaz, ale ako sa môžem spojiť 4?

Ako prístupov som našiel tak ďaleko MultiSearch a Disjunction Max Dotaz. MultiSearch vyzerá to, že nepodporuje celkové počty strán. Pokiaľ ide Disjunction Max Dotazu, mohlo byť, že som chýba les pre stromy, ale tam som bojuje v s subqueries byť náhodne zoradené iba v rámci sami pred pridaním nich jeden k druhému.

Tu, ako som sa napísať jeden dotaz, teraz bez Disjunction Max Queryv prípade, že pomáha:

{
  "query": {
    "bool": {
      "should": [
        {
          "term": {
            "isPlayer": true
          }
        },
        {
          "term": {
            "isEvil": true
          }
        }
      ]
    }
  }
}
elasticsearch
2021-11-22 13:35:49
1

Najlepšiu odpoveď

0

Riešenie tohto problému je to 4 samostatné skupiny, ale namiesto zabezpečenie všetci majú rôzne rozsahy skóre a triedenie podľa skóre. To možno dosiahnuť tým, že bodovanie hity a nie nejaký druh zodpovedajúce kritériá, ale cez skript-skóre oblasti. Toto pole vám umožňuje písať kód seba, že sa vráti logickú skóre (predvolený jazyk sa nazýva "bezbolestné", ale ja som videl príklady groovy, rovnako).

Logika je pomerne jednoduchý:

  1. Ak isPlayer = true, pridať 2 bodov o skóre
  2. Ak isEvil = true, pridať 4 bodov skóre
  3. Buď ako buď, pridať náhodné číslo medzi 0 a 1 na skóre na konci

To vytvára 4 skupiny som sa chcel s výraznou skóre-rozsahy:

  1. isPlayer = true, isEvil = true --> Skóre-rozsah: 6-7
  2. isPlayer = false, isEvil = true --> Skóre-rozsah: 4-5
  3. isPlayer = true, isEvil = false --> Skóre-rozsah: 2-3
  4. isPlayer = false, isEvil = false --> Skóre-rozsah: 0-1

Dotaz bude vyzerať takto:

  "query": {
    "script_score": {
      "query": {
        "match_all": {}
      },
      "script": {
        "source": """
            double score = 0;
            if(doc['isPlayer']){
              score += 2;
            }
            
            if(doc['isEvil']){
              score += 4;
            }
            
            int partialSeed = 1;
            score += randomScore(partialSeed, 'id');
            return score;
        """
      }
    }
  }
}
2021-11-24 08:51:50

V iných jazykoch

Táto stránka je v iných jazykoch

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................