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í
×

včera 13:11 | Nová verze

Po téměř dvou letech byla vydána nová verze 4.0 linuxové distribuce Audiophile Linux (též AP-Linux-V4). Tato distribuce vychází z Arch Linuxu, používá systemd, správce oken Fluxbox a vlastní real-time jádro pro nižší latence. Z novinek můžeme jmenovat podporu nových procesorů Intel Skylake a Kaby Lake nebo možnost instalace vedle jiných OS na stejný disk. Pokud se zajímáte o přehrávání hudby v Linuxu, doporučuji návštěvu webu této

… více »
Blaazen | Komentářů: 5
27.4. 18:55 | Nová verze

Byla vydána nová stabilní verze 1.9 (1.9.818.44) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují podporu nového vyhledávače Ecosia. Ten z příjmů z reklam podporuje výsadbu stromů po celém světě (YouTube). Nově lze přeskupovat ikonky rozšíření nebo řadit poznámky. Nejnovější Vivaldi je postaveno na Chromiu 58.0.3029.82.

Ladislav Hagara | Komentářů: 20
27.4. 17:00 | Nová verze

Byla vydána verze 3.7.0 svobodného systému pro správu obsahu (CMS) Joomla!. V oznámení o vydání (YouTube) se píše o 700 vylepšeních. Opraveno bylo také 8 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
27.4. 08:22 | Komunita

Grsecurity (Wikipedie) je sada bezpečnostních patchů pro linuxové jádro (porovnání se SELinuxem, AppArmorem a KSPP). Od září 2015 nejsou stabilní verze těchto patchů volně k dispozici. Dle včerejšího oznámení (FAQ) nejsou s okamžitou platností volně k dispozici už ani jejich testovací verze.

Ladislav Hagara | Komentářů: 73
26.4. 23:33 | Komunita

OpenBSD 6.1 vyšlo již 11. dubna. Po dvou týdnech byla vydána i oficiální píseň. Její název je Winter of 95 a k dispozici je ve formátech MP3 a OGG.

Ladislav Hagara | Komentářů: 0
26.4. 18:55 | Nová verze

Byla vydána verze 2017.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux. S vydáním verze 2016.1 se Kali Linux stal průběžně aktualizovanou distribucí. Aktualizovat jej lze pomocí příkazů "apt update; apt dist-upgrade; reboot".

Ladislav Hagara | Komentářů: 0
26.4. 18:22 | Nová verze

Po téměř pěti letech od vydání verze 2.00 byla vydána nová stabilní verze 2.02 systémového zavaděče GNU GRUB (GRand Unified Bootloader). Přehled novinek v souboru NEWS.

Ladislav Hagara | Komentářů: 25
26.4. 17:55 | Komunita

Vývojáři Debianu oznámili, že od 1. listopadu letošního roku nebudou jejich archivy dostupné pomocí protokolu FTP. Již v lednu oznámil ukončení podpory FTP kernel.org (The Linux Kernel Archives).

Ladislav Hagara | Komentářů: 28
26.4. 17:00 | Bezpečnostní upozornění

V oblíbeném webmailu postaveném na PHP SquirrelMail (Wikipedie) byla nalezena bezpečnostní chyba CVE-2017-7692, jež může být útočníkem zneužita ke spuštění libovolných příkazů a kompletnímu ovládnutí dotčeného serveru. Zranitelnost se týká pouze instancí, kde je pro transport používán Sendmail.

Ladislav Hagara | Komentářů: 3
26.4. 13:11 | Zajímavý článek

Soudní dvůr Evropské unie rozhodl (tisková zpráva) ve věci C-527/15: Prodej multimediálního přehrávače, který umožňuje zdarma a jednoduše zhlédnout na televizní obrazovce filmy protiprávně zpřístupněné na internetu, může představovat porušení autorského práva.

Ladislav Hagara | Komentářů: 32
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (35%)
 (1%)
 (6%)
 (45%)
 (9%)
Celkem 345 hlasů
 Komentářů: 50, poslední 27.4. 04:06
    Rozcestník

    Dotaz: Jak získat všechny řádky z MySQL jako objekt

    23.6.2016 12:29 Host
    Jak získat všechny řádky z MySQL jako objekt
    Přečteno: 694×
    Ahoj, snažím se získat z MySQL data tak, abych k nim mohl přistupovat jako k objektům, jenže dostanu pouze jeden objekt s jedním řádkem z MySQL.
    function ... () {
    $obj = false ;
    $sql = "SELECT * FROM site ORDER BY id ASC";
    $stmt = $this->pdo->prepare($sql);
    $stmt->execute();
    if ($stmt->rowCount() != 0){
      $obj = $stmt->fetch( \ PDO :: FETCH_OBJ);
    }
    return $obj ;
    }
    Pomůže prosím někdo ? Děkuji

    Řešení dotazu:


    Odpovědi

    Řešení 1× (DarkKnight)
    23.6.2016 13:17 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    function ... () {
        $sql = "SELECT * FROM site ORDER BY id ASC";
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute();
        return $stmt->fetchAll(\PDO::FETCH_OBJ);
    }
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 11:32 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Ahoj, děkuji za opravu a omlouvám se za pozdější reakci, byl jsem mimo domov. Hledal jsem pro funkci fetchAll() nějaký vhodný parametr, který by zajistil pro identifikaci něco jiného než čísla, nenašel jsem ale nic, musím tedy projít výsledek třeba foreachem a vytvořit si vlastní pole ? Děkuji
    28.6.2016 11:53 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Je to tam. Je potřeba si trochu pohrát s PDO::FETCH_GROUP, viz fetchAll(). Jako první sloupec v SELECTu musí být ten klíčový.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 12:30 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Tak FETCH_GROUP sice nahradí čísla požadovaným sloupcem
    $obj = $stmt->fetchAll( \ PDO :: FETCH_GROUP);
    ale zase vkládá čísla mezi každý sloupec :-( Pomůžeš prosím ještě ? Díky
    28.6.2016 12:35 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Je to tam v komentářích.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 12:49 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Nemůžu to najít, ale to je fuk, stejně nic z toho nevrací objekt v pravém slova smyslu, vytvořím si cyklem as. pole a výsledek bude zcela stejný. Díky.
    28.6.2016 12:57 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    fetchAll() v principu nemůže vracet objekt, ale jen kolekci. To jen pro upřesnění.

    Vždyť to tam vidím:
    $data = $stmt->fetchAll(PDO::FETCH_GROUP | PDO::FETCH_UNIQUE);
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 13:14 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    fetchAll() v principu nemůže vracet objekt, ale jen kolekci. To jen pro upřesnění.
    Aha a co tedy použít místo fetchAll().

    ***********

    $data = $stmt->fetchAll(PDO::FETCH_GROUP | PDO::FETCH_UNIQUE);
    použití
    $obj = $stmt->fetchAll(\PDO::FETCH_GROUP);
    nebo
    $obj = $stmt->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE);
    je vcelku jedno, stejně mezi každý název sloupce vkládá číselné pořadí sloupce i s jeho hodnotou :(
    28.6.2016 14:40 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    $obj = $stmt->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE);
    je vcelku jedno, stejně mezi každý název sloupce vkládá číselné pořadí sloupce i s jeho hodnotou :(
    Nedává. Podívej se pořádně. Jako klíč je použita hodnota z prvního sloupce.

    Schválně jsem si to vyzkoušel, abych si ověřil, že nekecám:
    <?php
    $db = new \PDO('mysql:host=localhost;dbname=test;charset=UTF8');
    $select = $db->prepare('SELECT name, id, author_id FROM book');
    $select->execute();
    $data = $select->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE | \PDO::FETCH_ASSOC);
    print_r($data);
    
    Výsledek:
    Array
    (
        [Babička] => Array
            (
                [id] => 1
                [author_id] => 1
            )
    
        [Divá Bára] => Array
            (
                [id] => 2
                [author_id] => 1
            )
    
        [Válka s mloky] => Array
            (
                [id] => 4
                [author_id] => 2
            )
    
    )
    
    Kde vidíš pořadí sloupce i s jeho hodnotou?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 14:50 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Ještě můžeš místo FETCH_ASSOC použít FETCH_OBJ, abys měl kolekci objektů.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.6.2016 16:13 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Kde vidíš pořadí sloupce i s jeho hodnotou?
    Díky, teď už nikde, jelikož se taky tohle
    $data = $select->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE | \PDO::FETCH_ASSOC);
    vypisuje jinak než tohle.. ;-)
    $data = $select->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE);

    A lépe ta data získat nepůjdou, jo? Abych mohl použít
    echo $data->babicka->author_id ;
    28.6.2016 16:29 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    To víš, že to jde:
    <?php
    // ...
    $data = (object) $select->fetchAll(\PDO::FETCH_GROUP | \PDO::FETCH_UNIQUE | \PDO::FETCH_OBJ);
    echo $data->Babička->author_id;
    Jen to není příliš rozumné řešení, protože to má několik nevýhod - například se to nedá procházet přes foreach. Blbě se řeší neexistující klíče. Kolekce je v daném případě prostě výhodnější.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    29.6.2016 13:28 Host
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Paráda, tohle jsem hledal, děkuji!

    Foreach mi funguje normálně, existence klíčů taky, zatím jsem nenarazil na žádný problém.. Ještě jednou díky.
    28.6.2016 18:45 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
    Ještě bych k tomu dodal, že programování není jen cut&paste nebo klikání na ikony. Občas je nutné se do toho manuálu prostě začíst. Prostě bys měl vědět, kdy potřebuješ FETCH_ARRAY nebo FETCH_ASSOC a kdy FETCH_OBJ. PDO je hodně chytrá třída, se kterou se dají dělat kouzla. Taková, že se z ORM stanou jen nesmyslné kusy kódu.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    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.