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 03:11 | Nová verze

    CyberChef byl vydán v nové major verzi 11. Přehled novinek v Changelogu. CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag).

    Ladislav Hagara | Komentářů: 0
    včera 20:11 | Nová verze

    Byla vydána nová verze 2.4.67 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 11 zranitelností.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Zajímavý software

    Brush (Bo(u)rn(e) RUsty SHell) je v Rustu napsaný shell kompatibilní s Bash (Bourne Again SHell). Vydána byla verze 0.4.0.

    Ladislav Hagara | Komentářů: 2
    včera 04:44 | Komunita

    Google zveřejnil seznam 1 141 projektů (vývojářů) od 184 organizací přijatých do letošního, již dvaadvacátého, Google Summer of Code. Přihlášeno bylo celkově 23 371 projektů od 15 245 vývojářů ze 131 zemí.

    Ladislav Hagara | Komentářů: 3
    včera 03:00 | Komunita

    Na čem pracovali vývojáři GNOME a KDE Plasma minulý týden? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.

    Ladislav Hagara | Komentářů: 0
    3.5. 03:44 | Nová verze

    Open source počítačová hra na hrdiny NetHack (Wikipedie, GitHub) byla vydána v nové verzi 5.0.0. První verze této hry byla vydána v roce 1987.

    Ladislav Hagara | Komentářů: 4
    1.5. 15:11 | IT novinky

    Evropská komise naléhavě vyzvala členské státy EU, aby kvůli ochraně nezletilých na internetu urychlily zavádění unijní aplikace pro ověřování věku a zajistily její dostupnost do konce roku. Členské státy mohou zavést aplikaci EU pro ověřování věku jako samostatnou aplikaci nebo ji integrovat do takzvané evropské peněženky digitální identity.

    Ladislav Hagara | Komentářů: 42
    30.4. 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    30.4. 23:11 | Nová verze

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    30.4. 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 46
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (32%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1495 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    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: 477×
    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.