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 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 10:55 | Nová verze

    Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 4
    dnes 09:33 | IT novinky

    Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.

    Ladislav Hagara | Komentářů: 1
    dnes 04:44 | Nová verze

    Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.

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

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    včera 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 2
    včera 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 1
    včera 11:33 | Nová verze

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

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

    Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 05:00 | Nová verze

    Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1680 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: PHP - nahrazení funkce foreach

    28.10.2013 13:27 Martin
    PHP - nahrazení funkce foreach
    Přečteno: 416×
    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.