abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 16:33 | Nová verze

    Svobodná historická realtimová strategie 0 A.D. (Wikipedie) byla vydána ve verzi 28 (0.28.0). Její kódový název je Boiorix. Představení novinek v poznámkách k vydání. Ke stažení také na Flathubu a Snapcraftu.

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

    Multimediální server a user space API PipeWire (Wikipedie) poskytující PulseAudio, JACK, ALSA a GStreamer rozhraní byl vydán ve verzi 1.6.0 (Bluesky). Přehled novinek na GitLabu.

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

    UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.2 a 20.04 OTA-12.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.0 otevřeného operačního systému pro chytré hodinky AsteroidOS (Wikipedie). Přehled novinek v oznámení o vydání a na YouTube.

    Ladislav Hagara | Komentářů: 1
    včera 16:00 | Zajímavý software

    WoWee je open-source klient pro MMORPG hru World of Warcraft, kompatibilní se základní verzí a rozšířeními The Burning Crusade a Wrath of the Lich King. Klient je napsaný v C++ a využívá vlastní OpenGL renderer, pro provoz vyžaduje modely, grafiku, hudbu, zvuky a další assety z originální kopie hry od Blizzardu. Zdrojový kód je na GitHubu, dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 6
    včera 13:33 | IT novinky

    Byl představen ICT Supply Chain Security Toolbox, společný nezávazný rámec EU pro posuzování a snižování kybernetických bezpečnostních rizik v ICT dodavatelských řetězcích. Toolbox identifikuje možné rizikové scénáře ovlivňující ICT dodavatelské řetězce a na jejich podkladě nabízí koordinovaná doporučení k hodnocení a mitigaci rizik. Doporučení se dotýkají mj. podpory multi-vendor strategií a snižování závislostí na vysoce

    … více »
    Ladislav Hagara | Komentářů: 4
    včera 12:22 | Humor

    Nizozemský ministr obrany Gijs Tuinman prohlásil, že je možné stíhací letouny F-35 'jailbreaknout stejně jako iPhony', tedy upravit jejich software bez souhlasu USA nebo spolupráce s výrobcem Lockheed Martin. Tento výrok zazněl v rozhovoru na BNR Nieuwsradio, kde Tuinman naznačil, že evropské země by mohly potřebovat větší nezávislost na americké technologii. Jak by bylo jailbreak možné technicky provést pan ministr nijak nespecifikoval, nicméně je známé, že izraelské letectvo ve svých modifikovaných stíhačkách F-35 používá vlastní software.

    NUKE GAZA! 🎆 | Komentářů: 34
    včera 06:00 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 162 (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 05:55 | IT novinky

    Sdružení CZ.NIC, správce české národní domény, zveřejnilo Domain Report za rok 2025 s klíčovými daty o vývoji domény .CZ. Na konci roku 2025 bylo v registru české národní domény celkem 1 515 860 s koncovkou .CZ. Průměrně bylo měsíčně zaregistrováno 16 222 domén, přičemž nejvíce registrací proběhlo v lednu (18 722) a nejméně pak v červnu (14 559). Podíl domén zabezpečených pomocí technologie DNSSEC se po několika letech stagnace výrazně

    … více »
    Ladislav Hagara | Komentářů: 9
    18.2. 18:33 | IT novinky

    Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.

    Ladislav Hagara | Komentářů: 14
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (11%)
     (27%)
     (3%)
     (4%)
     (2%)
     (12%)
     (26%)
    Celkem 918 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    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: 799×

    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.