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

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia online tabulky Proton Sheets v Proton Drive.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | Komunita

    O víkendu (15:00 až 23:00) probíha EmacsConf 2025, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji lze na stránkách konference. Záznamy budou k dispozici přímo z programu.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Komunita

    Provozovatel internetové encyklopedie Wikipedia jedná s velkými technologickými firmami o uzavření dohod podobných té, kterou má s Googlem. Snaží se tak zpeněžit rostoucí závislost firem zabývajících se umělou inteligencí (AI) na svém obsahu. Firmy využívají volně dostupná data z Wikipedie k trénování jazykových modelů, což zvyšuje náklady, které musí nezisková organizace provozující Wikipedii sama nést. Automatické programy

    … více »
    Ladislav Hagara | Komentářů: 16
    včera 15:22 | IT novinky

    Evropská komise obvinila síť 𝕏 z porušení unijních pravidel, konkrétně nařízení Evropské unie o digitálních službách (DSA). Vyměřila jí za to pokutu 120 milionů eur (2,9 miliardy Kč). Pokuta je podle názoru amerického ministra zahraničí útokem zahraničních vlád na americký lid. K pokutě se vyjádřil i americký viceprezident: „EU by měla podporovat svobodu projevu, a ne útočit na americké společnosti kvůli nesmyslům“.

    Ladislav Hagara | Komentářů: 13
    5.12. 17:11 | IT novinky

    Společnost Jolla spustila kampaň na podporu svého nového telefonu Jolla Phone se Sailfish OS. Dodání je plánováno na první polovinu příštího roku. Pokud bude alespoň 2 000 zájemců. Záloha na telefon je 99 €. Cena telefonu v rámci kampaně je 499 €.

    Ladislav Hagara | Komentářů: 28
    5.12. 15:11 | IT novinky

    Netflix kupuje Warner Bros. včetně jejích filmových a televizních studií HBO Max a HBO. Za 72 miliard dolarů (asi 1,5 bilionu korun).

    Ladislav Hagara | Komentářů: 2
    5.12. 14:11 | IT novinky

    V Las Vegas dnes končí pětidenní konference AWS re:Invent 2025. Společnost Amazon Web Services (AWS) na ní představila celou řadu novinek. Vypíchnout lze 192jádrový CPU Graviton5 nebo AI chip Trainium3.

    Ladislav Hagara | Komentářů: 0
    5.12. 00:33 | Nová verze

    Firma Proxmox vydala novou serverovou distribuci Datacenter Manager ve verzi 1.0 (poznámky k vydání). Podobně jako Virtual Environment, Mail Gateway či Backup Server je založená na Debianu, k němuž přidává integraci ZFS, webové administrační rozhraní a další. Datacenter Manager je určený ke správě instalací právě ostatních distribucí Proxmox.

    |🇵🇸 | Komentářů: 12
    4.12. 23:44 | Nová verze

    Byla vydána nová verze 2.4.66 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 5 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    4.12. 14:00 | IT novinky

    Programovací jazyk JavaScript (Wikipedie) dnes slaví 30 let od svého oficiálního představení 4. prosince 1995.

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (48%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (16%)
     (18%)
    Celkem 435 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    Rozcestník

    Dotaz: PHP - nahrazení funkce foreach

    28.10.2013 13:27 Martin
    PHP - nahrazení funkce foreach
    Přečteno: 412×
    Ahoj, čím bych mohl nahradit ten foreach? Potřebuji načíst jeden údaj z MySQL a nechci to pomocí cyklu, myslím, že je to zbyteční přes cyklus když je tam jen jeden řádek, ne? Děkuji
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array($email, $pass));
    $id = $stmt->fetchAll();
    
    if($stmt->rowCount() === 1)
    {
         $this->mess('Jste přihlášeni!');
         foreach($id as $row)
         {
              echo $row['id'];
         }
    }
    else
    {
       $this->error('Zadané údaje jsou neplatné!');
    }

    Řešení dotazu:


    Odpovědi

    28.10.2013 13:53 gsnak | skóre: 22 | blog: gsnak
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    Ano.
    Čo Rys, to vrah!
    28.10.2013 14:08 Kit
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    Místo fetchAll() použít jen fetch() nebo ještě lépe fetchColumn():
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array($email, $pass));
    $id = $stmt->fetchColumn();
    
    if ($id === false)
        throw new Exception('Zadané údaje jsou neplatné!');
    
    $this->mess('Jste přihlášeni!');
    echo $id;
    
    28.10.2013 14:27 Martin
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    Díky moc, a když bych chtěl k tomu id ještě jeden údaj z dalšího sloupce ze stejného řádku, tak to bude takto?
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array($email, $pass));
    $id = $stmt->fetchColumn();
    $name = $stmt->fetchColumn();
    
    if ($id === false OR $name === false)
        throw new Exception('Zadané údaje jsou neplatné!');
    
    $this->mess('Jste přihlášeni!');
    echo $id;
    echo $name;
    Děkuji
    28.10.2013 14:44 Kit
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    Ne, takhle to nelze. Použiješ klasický fetch()
    $stmt = $pdo->prepare($sql);
    $stmt->execute(array($email, $pass));
    list($id, $name) = $stmt->fetch();
    
    if ($id === false || $name === false)
        throw new Exception('Zadané údaje jsou neplatné!');
    
    $this->mess('Jste přihlášeni!');
    echo $id;
    echo $name;
    Pozor na "OR", slouží k jinému účelu a má jinou prioritu. V daném případě je však test $name === false zbytečný.
    AraxoN avatar 28.10.2013 15:17 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    Použitím funkcie reset():
    $row=reset($id);
    echo $row["id"];
    28.10.2013 15:29 Kit
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    To už zrovna může vytáhnout i tu požadovanou hodnotu $name
    list($ident, $name) = reset($id);
    echo "ident = $ident, name = $name\n";
    AraxoN avatar 28.10.2013 17:30 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: PHP - nahrazení funkce foreach
    môže, ale v pôvodnom kóde mal len echo $row['id'];

    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.