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í
×
    včera 17:44 | Zajímavý článek

    Jak si zobrazit pomocí Chrome a na Chromiu založených webových prohlížečích stránky s neplatným certifikátem? Stačí napsat thisisunsafe.

    Ladislav Hagara | Komentářů: 0
    včera 00:33 | Bezpečnostní upozornění

    V repozitáři AUR (Arch User Repository) linuxové distribuce Arch Linux byly nalezeny a odstraněny tři balíčky s malwarem. Jedná se o librewolf-fix-bin, firefox-patch-bin a zen-browser-patched-bin.

    Ladislav Hagara | Komentářů: 9
    včera 00:22 | Komunita

    Dle plánu by Debian 13 s kódovým názvem Trixie měl vyjít v sobotu 9. srpna.

    Ladislav Hagara | Komentářů: 0
    19.7. 13:22 | Komunita

    Vývoj linuxové distribuce Clear Linux (Wikipedie) vyvíjené společností Intel a optimalizováné pro jejich procesory byl oficiálně ukončen.

    Ladislav Hagara | Komentářů: 1
    18.7. 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    18.7. 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 1
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 4
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 6
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (26%)
     (18%)
     (6%)
     (6%)
     (3%)
     (6%)
     (3%)
     (32%)
    Celkem 34 hlasů
     Komentářů: 4, poslední včera 16:33
    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: 352×
    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.