abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

    Ladislav Hagara | Komentářů: 0
    dnes 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Nová verze

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

    Ladislav Hagara | Komentářů: 0
    dnes 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 11
    včera 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 748 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: RANDOM select a hlasy v jiné tabulce

    26.3.2013 07:03 RYU.cz | skóre: 16 | Vsetín
    RANDOM select a hlasy v jiné tabulce
    Přečteno: 744×

    Zdravím, mám tabulku záznamů (cca 5-6k) pro které uživatelé hlasují. Skóre je uloženo u každého záznamu a hlasy jsou v další tabulce, kde je i ID záznamu a ID klienta. Nad hlavní tabulkou probíhá random select. Vše je ok, dokud nepotřebuji klientovi poskytnout záznam který ještě nehodnotil. Zatím jsem to vyřešil tak, že se po random vyselectuje ještě hlas a pokud vrátí nenulový výsledek, random se provádí znovu. Pokud ale klient má většinu záznamů ohodnocenou, může se na konec vykonávat počet hlasů + 1 dotazů a to se mi moc nelíbí.

    Další možnost, která mě napadla je vybrat si všechny hlasy uživatele a pak přidat do random dotazu WHERE id NOT IN(...) ale takový dotaz by nakonec byl extrémně dlouhý.

    Struktura:
    zaznamy:   ID   hash   data   skore   pocet_hlasu   pocet_precteni
               int  vch    txt    int     int           int
               PRK
               \
                \ Vazba pres id zaznamu
                  -------
                          \     
                           \     
    hlasy:     ID   klient DID    skore   cas
               int  vch    int    int     timestamp
               PRK
    
    
    Linux is like a teepee - no windows, no gates, apache inside. | RYU.cz

    Odpovědi

    Tarmaq avatar 26.3.2013 12:00 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    jak jako dlouhy?
    WHERE id NOT IN (
      SELECT did
      FROM hlasy
      WHERE klient = id_prihlaseneho_uzivatele
    )
    
    Don't panic!
    26.3.2013 13:20 RYU.cz | skóre: 16 | Vsetín
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    SELECT did FROM hlasy WHERE klient = id_prihlaseneho_uzivatele muze vratit az 5 tisic zaznamu
    Linux is like a teepee - no windows, no gates, apache inside. | RYU.cz
    26.3.2013 13:37 Kit
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    A to je problém?
    26.3.2013 17:33 kaaja | skóre: 24 | blog: Sem tam něco | Podbořany, Praha
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    A co
    select * from ankety 
    left join hlasy on ankety.id = hlasy.id_ankety and klient = id_prihlaseneho_uzivatele
    where hlasy.id_ankety is null
    Ono 5000 by zas pro databázi nemělo být až tak moc.
    26.3.2013 18:02 kuka
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    To uz je asi citelnejsi s pouzitim not exists (je to de facto to slovni zadani prepsane do "anglictiny") a vsechny uvedene varianty (exists, in, left join) se v rozumne databazi provedou vicemene stejne. 5000 zaznamu neni vubec nic.
    26.3.2013 18:01 RYU.cz | skóre: 16 | Vsetín
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    Děkuji za tipy, vyzkouším.
    Linux is like a teepee - no windows, no gates, apache inside. | RYU.cz
    27.3.2013 00:05 Logik
    Rozbalit Rozbalit vše Re: RANDOM select a hlasy v jiné tabulce
    A jak vůbec děláš random select? Rozhodně to nedělej stylem: vyberu všechny kam můžu hlasovat a pak z něj náhodně vyberu. Pokud Ti nezáleží na úplně uniformním rozdělení pravděpodobnosti, tak můžeš použít:

    SELECT * FROM zaznamy ORDER BY id OFFSET RANDOM(SELECT count(*) FROM zaznamy) WHERE Id NOT IN (SELECT did FROM hlasy WHERE klient = XY) LIMIT 1

    Pozor na něco ve stylu .... ORDER BY RANDOM() to vede na ugly full table scan.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.