abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 06:33 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2024, jež probíhá tento víkend v Praze v prostorách Fakulty informačních technologií Českého vysokého učení v Praze (FIT ČVUT). Na programu je spousta zajímavých přednášek.

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

    Elon Musk na akci We, Robot (YouTube, 𝕏) představil Robotaxi, Robovan a vylepšeného Tesla Bota (Optimus).

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

    Internet Archive je offline (𝕏, Bluesky, Mastodon‪). Unikly údaje 31 milionů uživatelů. Probíhal / probíhá na něj DDoS útok.

    Ladislav Hagara | Komentářů: 0
    včera 05:22 | Komunita

    Alyssa Rosenzweig se v příspěvku na svém blogu rozepsala o hraní AAA her na Asahi Linuxu. Na YouTube je záznam její včerejší přednášky na XDC 2024 (X.Org Developer's Conference).

    Ladislav Hagara | Komentářů: 9
    včera 04:55 | IT novinky

    Vláda schválila Národní polovodičovou strategii: Česká republika má velký potenciál stát se významným hráčem v oblasti výroby čipů, zejména v evropském měřítku. Využít tento potenciál je cílem Národní polovodičové strategie, kterou připravilo Ministerstvo průmyslu a obchodu ve spolupráci s experty, a která navazuje na evropský Akt o čipech.

    Ladislav Hagara | Komentářů: 2
    10.10. 18:11 | Zajímavý software

    V lete vyšiel Aeonwave 4.0, ktorý niekoľkonásobne menej vyťažuje procesor pri interpretácií priestorového zvuku než OpenAL Soft. Autor hľadá prispievateľov do knižnice libaaxopenal za účelom pridania ALC_EXT_EFX rozšírení využívaných napr. v hre Doom 3 cez port Dhewm3 v Linuxe.

    atirage21 | Komentářů: 5
    10.10. 15:33 | Nová verze

    Linuxová distribuce Ubuntu 24.10 „Oracular Oriole“ byla vydána. Jde o průběžné vydání s podporou 9 měsíců. Obsahuje mj. Linux 6.11 či GNOME 47 s několika odkazy na první vydání Ubuntu (4.10 „Warty Warthog“) před 20 lety. K dispozici jsou také oficiální deriváty s odlišnými výchozími desktopovými prostředími anebo balíky aplikací.

    Fluttershy, yay! | Komentářů: 2
    10.10. 13:55 | Nová verze

    Deno (Wikipedie), běhové prostředí (runtime) pro JavaScript, TypeScript a WebAssembly, bylo vydáno v nové major verzi 2.0 (YouTube). Důležité změny v Migration Guide.

    Ladislav Hagara | Komentářů: 3
    10.10. 13:33 | Nová verze

    Apache Tomcat (Wikipedie) slaví 25 let. Při té příležitosti byla vydána nová verze 11.0. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    10.10. 12:44 | Nová verze

    Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 24.09.0. Přehled novinek v poznámkách k vydání. O3DE má nového maskota: Odie.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: PHP - nahrazení funkce foreach

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