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 15:22 | IT novinky

    Ve věku 91 let zemřel izraelský informatik Ja'akov Ziv, spolutvůrce bezztrátových kompresních algoritmů LZ77, LZ78 a LZW (Lempel–Ziv–Welch).

    Ladislav Hagara | Komentářů: 0
    dnes 11:00 | IT novinky

    Byla představena nová Arduino deska Arduino UNO R4 s 32bitovým MCU RA4M1 (Arm Cortex-M4). Desku lze zatím získat pouze v rámci early access programu.

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

    Operační systém MidnightBSD, fork FreeBSD optimalizovaný pro desktop s prostředím Xfce, byl vydán ve verzi 3.0. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 4
    včera 18:22 | IT novinky

    Na GOG.com běží Spring Sale. Při té příležitosti lze získat zdarma počítačovou hru Neurodeck: Psychological Deckbuilder (ProtonDB).

    Ladislav Hagara | Komentářů: 0
    25.3. 12:33 | Komunita

    Alex Ellis upozornil 15. března, že firma Docker se chystala zrušit bezplatný hosting open-source projektů na Docker Hubu. Po vlně odporu se představitelé firmy omluvili a posléze byl původní záměr odvolán.

    Fluttershy, yay! | Komentářů: 29
    25.3. 07:00 | IT novinky

    Ve věku 94 let zemřel Gordon Moore, mj. spoluzakladatel společnosti Intel a autor Moorova zákona.

    Ladislav Hagara | Komentářů: 1
    24.3. 17:11 | Nová verze

    Mercurial (Wikipedie), software pro SCM (Source Code Management), byl vydán ve verzi 6.4. Přehled novinek v poznámkách k vydání. Ve dnech 5. až 7. dubna proběhne konference Mercurial Paris.

    Ladislav Hagara | Komentářů: 0
    24.3. 11:55 | IT novinky

    Byly rozdány Ceny Velkého bratra (Big Brother Awards) za rok 2022 pro největší slídily pořádané nevládní organizací Iuridicum Remedium. Dlouhodobý slídil: Microsoft. Firemní slídil: Seznam. Úřední slídil: Nejvyšší správní soud. Výrok Velkého bratra: Marian Jurečka. Pozitivní cena: NoLog.

    Ladislav Hagara | Komentářů: 11
    24.3. 11:11 | Zajímavý projekt

    Byla představena online vzdělávací platforma Ada Computer Science pro učitele, studenty a kohokoli, kdo se zajímá o informatiku. Stojí za ní Raspberry Pi Foundation a Univerzita v Cambridgi.

    Ladislav Hagara | Komentářů: 0
    24.3. 09:11 | Bezpečnostní upozornění

    GitHub má nový RSA SSH klíč. Předchozí soukromý klíč byl krátce vystaven na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Používáte WSL (Windows Subsystem for Linux)?
     (74%)
     (12%)
     (4%)
     (11%)
    Celkem 336 hlasů
     Komentářů: 4, poslední 24.3. 06:42
    Rozcestník


    Dotaz: nahodne namiesanie vysledkov z mnoziny udajov

    24.3.2014 15:46 adrinko | skóre: 22
    nahodne namiesanie vysledkov z mnoziny udajov
    Přečteno: 309×
    Dobry den, v mysql tabulke "vsetky" mam 9 000 zaznamov (tie sa nemenia, teda len obcas pribudne novy). Potreboval by som vsak do tabulky "zmiesane" kazdy den z tych 9 000 namiesat 70 000 zaznamov cez PHP. Premiesavanie by vsak malo byt vzdy nahodne, niektore sa budu opakovat, malo by byt vsak tak nahodne, ze niektore riadky kludne nemusia byt v niektory den namiesane. A kazdy den by mala byt ta zmiesanina ina (v priebehu celeho roka).

    Stretli ste sa niekto s niecim takymto, alebo len ja tak vymyslam? :-) V kazdom pripade netusim, ako to takymto sposobom premiesat a kludne aj viackrat premiesat.

    Moja predstava je taka, ze si kazdy den o polnoci predpripravim takuto zmiesaninu s datumom noveho dna a potom si uz skript iba vzdy siahne do db pre dalsi zaznam a spatne zaznaci, ze uz bol dany zaznam dnes vybraty. Diky moc za navedenie na cestu.

    Odpovědi

    24.3.2014 16:24 dan
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    mozno cez ORDER BY RAND()
    24.3.2014 16:49 axel
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    Vygeneruj si 70000 nahodnych cisel z rozsahu 1-9000. Pak si urci deterministicke poradi zdrojovych dat (napr. setridene dle PK) a podle pripravenych indexu je uloz do cilove tabulky. Podminka na unikatnost kazdy den je dost silna - bud budes muset kontrolovat, zda ses nahodou netrefil, vuci vsem dnum, nebo se spolehnes, ze pravdepodobnost takoveho jevu je miziva. Pokud bys chtel kontrolovat, doporucuju spocitat si hash posloupnosti pouzitych indexu a ten si ulozit (pri shode prepocitas, mozna zbytecne, ale porad to bude levnejsi nez porovnavat mnoziny dat).
    24.3.2014 19:13 adrinko | skóre: 22
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    Dan, Axel, dakujem vam obom.
    24.3.2014 19:36 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    Předpokládám, že DBE MySQL takže ORDER BY RAND() zafunguje, ale jestli to je M$SQL, tak ne, tam se hodnota RAND() generuje pro dotaz, ne pro řádek.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Tarmaq avatar 25.3.2014 08:55 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    v MSSQL by zafungovalo ORDER BY NEWID(), ale asi to je zbytecne resit, protoze tazatel psal ze to potrebuje pro MySQL
    Don't panic!
    25.3.2014 09:10 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    Hm, zas nedávám pozor, je to v dotazu napsané…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    25.3.2014 13:16 Logik
    Rozbalit Rozbalit vše Re: nahodne namiesanie vysledkov z mnoziny udajov
    Jde to jednodušeji - bez generování nějaké tabulky http://stackoverflow.com/questions/6541644/selecting-random-rows-with-mysql

    SET @r := (SELECT ROUND(RAND() * (SELECT COUNT(*) FROM mytable)));
    SET @sql := CONCAT('SELECT * FROM mytable LIMIT 1 OFFSET ', @r);
    PREPARE stmt1 FROM @sql;
    EXECUTE stmt1;

    Popř. lze samozřejmě dotaz složit i na klientovi, todle je čistě MySQL řešení...

    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.