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 | Komunita

    Kalifornský zákon AB 1043 platný od 1. ledna 2027 vyžaduje, aby operační systémy požadovaly po uživatelích věk nebo datum narození a skrze API poskytovaly aplikacím informaci, zda je uživatel mladší 13 let, má 13 až 16 let, má 16 až 18 let nebo má alespoň 18 let. Vývojáři linuxových distribucí řeší, co s tím (Ubuntu, Fedora, …).

    Ladislav Hagara | Komentářů: 2
    dnes 11:44 | Pozvánky

    Konference LinuxDays 2026 proběhne o víkendu 3. a 4. října v Praze v areálu ČVUT v Dejvicích na FIT. Čekají vás desítky přednášek, workshopy, stánky a setkání se spoustou chytrých lidí.

    Petr Krčmář | Komentářů: 0
    dnes 00:44 | Humor

    Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀

    Ladislav Hagara | Komentářů: 1
    včera 21:55 | IT novinky Ladislav Hagara | Komentářů: 2
    včera 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 2
    včera 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    2.3. 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

    Ladislav Hagara | Komentářů: 15
    2.3. 21:11 | Zajímavý software

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    2.3. 20:33 | IT novinky

    Byla oznámena spolupráce GrapheneOS s Motorolou. Podrobnosti v tiskové zprávě. GrapheneOS (Wikpedie) je varianta Androidu zaměřující se na bezpečnost a soukromí.

    Ladislav Hagara | Komentářů: 0
    2.3. 02:22 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 26.2.1. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (11%)
     (28%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1006 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: PHP - nahrazení funkce foreach

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