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

    Uživatelé komunikátoru Signal si mohou svá data přímo v Signalu bezpečně zálohovat a v případě rozbití nebo ztráty telefonu následně na novém telefonu obnovit. Zálohování posledních 45 dnů je zdarma. Nad 45 dnů je zpoplatněno částkou 1,99 dolaru měsíčně.

    Ladislav Hagara | Komentářů: 0
    včera 18:44 | Zajímavý článek

    Server Groklaw, zaměřený na kauzy jako právní spory SCO týkající se Linuxu, skončil před 12 lety, resp. doména stále existuje, ale web obsahuje spam propagující hazardní hry. LWN.net proto v úvodníku připomíná důležitost zachovávání komunitních zdrojů a upozorňuje, že Internet Archive je také jen jeden.

    Fluttershy, yay! | Komentářů: 2
    včera 14:22 | Nová verze

    Jakub Vrána vydal Adminer ve verzi 5.4.0: "Delší dobu se v Admineru neobjevila žádná závažná chyba, tak jsem nemusel vydávat novou verzi, až počet změn hodně nabobtnal."

    Ladislav Hagara | Komentářů: 1
    včera 13:22 | IT novinky

    V Německu slavnostně uvedli do provozu (en) nejrychlejší počítač v Evropě. Superpočítač Jupiter se nachází ve výzkumném ústavu v Jülichu na západě země, podle německého kancléře Friedricha Merze otevírá nové možnosti pro trénování modelů umělé inteligence (AI) i pro vědecké simulace. Superpočítač Jupiter je nejrychlejší v Evropě a čtvrtý nejrychlejší na světě (TOP500). „Chceme, aby se z Německa stal národ umělé inteligence,“ uvedl na

    … více »
    Ladislav Hagara | Komentářů: 12
    7.9. 04:11 | Komunita

    V Berlíně probíhá konference vývojářů a uživatelů desktopového prostředí KDE Plasma Akademy 2025. Při té příležitosti byla oznámena alfa verze nové linuxové distribuce KDE Linux.

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

    Byl vydán Debian 13.1, tj. první opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.12, tj. dvanáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 2
    5.9. 23:44 | IT novinky

    Evropská komise potrestala Google ze skupiny Alphabet pokutou 2,95 miliardy eur (71,9 miliardy Kč) za porušení antimonopolní legislativy. Podle EK, která mimo jiné plní funkci antimonopolního orgánu EU, se Google dopustil protisoutěžních praktik ve svém reklamním byznysu. Google v reakci uvedl, že rozhodnutí považuje za chybné a hodlá se proti němu odvolat. EK ve věci rozhodovala na základě stížnosti Evropské rady vydavatelů. Podle

    … více »
    Ladislav Hagara | Komentářů: 43
    5.9. 23:11 | Komunita

    Podpora 32bitového Firefoxu pro Linux skončí v roce 2026. Poslední podporované 32bitové verze budou Firefox 144 a Firefox 140 s rozšířenou podporou, jehož podpora skončí v září 2026.

    Ladislav Hagara | Komentářů: 3
    5.9. 19:33 | IT novinky

    Společnost Raspberry Pi nově nabízí Raspberry Pi SSD s kapacitou 1 TB za 70 dolarů.

    Ladislav Hagara | Komentářů: 12
    5.9. 15:55 | Zajímavý software

    Microsoft BASIC pro mikroprocesor 6502 byl uvolněn jako open source. Zdrojový kód je k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 14
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (3%)
     (3%)
     (2%)
    Celkem 156 hlasů
     Komentářů: 11, poslední 4.9. 16:12
    Rozcestník

    Dotaz: Problém s funkcí rand v php

    2.4.2012 11:41 SCP
    Problém s funkcí rand v php
    Přečteno: 451×
    Zdravím, mám v mysql 15364 řádků a potřebuji náhodně pro každý řádek vygenerovat v PHP náhodné číslo do 1 do 15635.

    zkoušel jsem to takto.. ale výsledek je takový, že se uloží stejné číslo cca 30x po sobě a pak následuje číslo jiné, nevíte proč nemá každý řádek jiné číslo? Díky
    for ($i = 1; $i < 15364; $i++) {
    $rand = rand(1,15635);
    $stmt = $pdo->prepare('UPDATE iny SET lok = ?');
    $stmt->execute(array($rand));
    $stmt->fetch(PDO::FETCH_ASSOC);
    }

    Řešení dotazu:


    Odpovědi

    2.4.2012 12:22 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    srand -uješ?
    2.4.2012 12:39 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Hele, rozumím dobře tomu, že se snažíš vygenerovat 15364 náhodný celých čísel rovnoměrně rozdělených v rozsahu 1 až 15635 a divíš se tomu, že ve výsledku jsi našel 30 stejných čísel? Pokud ano, obrat svoji pozornost ke statistice místo PHPka. :)
    2.4.2012 12:53 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Pardon, 30 je na tohle už moc, maximální počet stejných čísel by měl být spíš tak osm. Ale rozhodně nebudeš mít každé číslo jiné!

    Pokud jsem správně pochopil, co generuješ, tak v případě 30 shodných čísel máš rozbitý generátor anebo chybu někde jinde. Každopádně se srand to nemá moc společného.
    2.4.2012 13:06 Marble | skóre: 27 | blog: marble
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Podle komentářů u online manuálu PHPka to vypadá, že generátor od rand() může být na některých implementacích skutečně dost rozbitý. Někdo místo něj doporučoval mt_rand(). Kdyžtak víc viz dokumentace na php.net (já to zas moc podrobně nečetl).
    2.4.2012 14:08 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    30× po sobě je dost divné, 30× stejné číslo ve vygenerované množině asi nepravděpodobné, zkuste fci mt_rand().
    Nicméně co ten SQL příkaz?, každým dotazem upravujete pole lok ve všech záznamech tabulce iny, nějaký WHERE nechybí?
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    2.4.2012 14:30 SCP
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Ano, přesně tak, WHERE byl ten problém :-( Nechápu jak jsem to mohl přehlídnout :-(

    Tohle už funguje jak má... Díky moc
    for ($i = 1; $i < 15364; $i++) {
    $rand = rand(1,15635);
    $stmt = $pdo->prepare('UPDATE iny SET lok = ? WHERE id = ?');
    $stmt->execute(array($rand, $i));
    $stmt->fetch(PDO::FETCH_ASSOC);
    }
    rADOn avatar 2.4.2012 14:52 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Můžeš se taky na rand() v php úplně vybodnout a vyrobit si náhodné číslo sql funkcí.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    5.4.2012 12:18 Honza Vrana
    Rozbalit Rozbalit vše Re: Problém s funkcí rand v php
    Krasny den,

    chtel jsem napsat to same, pridavam priklad:

    UPDATE iny SET lok=round(rand()*1523);

    nevim jestli to nahodne cislo potrebujete furt stejne, jestli to nepouzivate jen na nahodne serazeni protoze pak lze v mysql pouzit i RAND pri selectu

    cily SELECT * FROM iny ORDER BY RAND();

    I kdyz pri vetsim poctu radku to nemusi mit zrovna optimalni vykon.

    Honza Vrana

    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.