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:11 | IT novinky

    Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 20:00 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.

    Ladislav Hagara | Komentářů: 0
    4.10. 15:22 | IT novinky

    Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.

    Ladislav Hagara | Komentářů: 30
    4.10. 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 14
    3.10. 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 9
    3.10. 19:00 | Nová verze

    Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    3.10. 17:11 | Upozornění

    eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.

    Ladislav Hagara | Komentářů: 33
    3.10. 17:00 | Komunita

    Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.

    Ladislav Hagara | Komentářů: 1
    3.10. 14:33 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (45%)
     (16%)
     (17%)
     (22%)
     (15%)
     (18%)
     (16%)
     (16%)
    Celkem 179 hlasů
     Komentářů: 12, poslední 4.10. 20:35
    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: 777×

    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.