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 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 1
    dnes 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

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

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

    Ladislav Hagara | Komentářů: 0
    dnes 00:22 | Nová verze

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Open source router Turris Omnia NG Wired je v prodeji. Jedná se o Turris Omnia NG bez Wi-Fi. Je připraven pro zamontování do racku.

    Ladislav Hagara | Komentářů: 6
    včera 11:44 | Pozvánky

    Sníh roztál a roztávají i bastlíři. Žene se na nás celá řada konferencí a seminářů technického rázu. Zajímá vás, jaké? Pak se připojte k 60. Virtuální Bastlírně, tedy k veřejné diskuzi bastlířů, techniků, učitelů i vědců. Jako vždy přijde na přetřes spousta novinek ze světa hardwaru, softwaru i bizáru. Na začátek lze očekávat hardwarová témata, tedy například nový KiCAD 10, nové akcelerátory LLM s nízkou spotřebou, nejvíce fosforeskující

    … více »
    bkralik | Komentářů: 1
    včera 11:22 | Zajímavý článek

    IuRe (Iuridicum Remedium) v rámci programu Digitální svobody zveřejnila analýzu dopadů a efektivity systémů ověřování věku v digitálním prostoru, která srovnává implementace ověřování věku v Austrálii, Velké Británii a Evropské unii.

    |🇵🇸 | Komentářů: 1
    včera 04:22 | Nová verze

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.3 (𝕏, Mastodon). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 03:55 | Nová verze

    Byla vydána nová verze 14.4 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 5
    9.3. 23:22 | Nová verze

    Databáze DuckDB (Wikipedie) byla vydána ve verzi 1.5.0. S kódovým názvem Variegata (husice rajská). Přináší řadu vylepšení, včetně nového ergonomičtějšího CLI klienta nebo podporu pro typ VARIANT a vestavěný typ GEOMETRY.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (6%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (12%)
     (25%)
    Celkem 1051 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.