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 00:55 | Komunita

Pocket (dříve Read It Later) (Wikipedie) je oblíbená služba umožňující uložit si článek z webu na později. V červnu 2015 s vydáním Firefoxu 38.0.5 se do té doby doplněk Pocket stal integrovanou součásti Firefoxu, a to i přes odpor celé řady uživatelů tohoto webového prohlížeče. Mozilla po měsících ustoupila a z integrované součásti se stal opět doplněk. Včera bylo oznámeno, že Mozilla službu Pocket kupila (Mozilla Blog, Pocket Blog).

Ladislav Hagara | Komentářů: 0
včera 23:55 | Pozvánky

Tentokrát jsme si pro vás připravili neobvyklou akci. Ve středu 1. 3. v 17:30 nás přivítá sdružení CZ.NIC ve svých prostorách v Milešovské ulici číslo 5 na Praze 3, kde si pro nás připravili krátkou prezentaci jejich činnosti. Následně navštívíme jejich datacentrum pod Žižkovskou věží. Provedou nás prostory, které jsou běžnému smrtelníkovi nedostupné!

… více »
xkucf03 | Komentářů: 0
včera 18:30 | Komunita

Jednodeskový počítač Raspberry Pi slaví již 5 let. Prodej byl spuštěn 29. února 2012. O víkendu proběhne v Cambridgi velká narozeninová party. Na YouTube bylo při této příležitosti zveřejněno video představující zajímavé projekty postavené na Raspberry Pi.

Ladislav Hagara | Komentářů: 0
včera 18:30 | Nová verze

Byla vydána verze 2017.1.1 svobodného multiplatformního leteckého simulátoru FlightGear. Kódový název a výchozí letiště této verze je Bergen. Přehled novinek v Changelogu.

Ladislav Hagara | Komentářů: 0
včera 10:50 | Zajímavý software

Mozilla.cz informuje o dvou nových experimentálních funkcích v programu Firefox Test Pilot (zprávička). Snooze Tabs slouží k odkládání panelů na později. Pokud vám někdo pošle odkaz, ale vy nemáte čas si stránku hned přečíst, můžete si naplánovat otevření panelu na později. Stačí kliknout na tlačítko a vybrat, kdy chcete panel otevřít. Firefox panel schová a ve vybraný čas znovu otevře. Pulse umožňuje ohodnotit, jak dobře stránka funguje, např. jak rychle se ve Firefoxu načetla. Podle nasbíraných hodnocení pak bude Mozilla prohlížeč ladit.

Ladislav Hagara | Komentářů: 7
včera 02:00 | IT novinky

V Barceloně probíhá veletrh Mobile World Congress 2017. Nokia na něm například představila (360° video na YouTube) novou Nokii 3310 (YouTube). BlackBerry představilo BlackBerry KEYone (YouTube) s QWERTY klávesnicí. LG představilo LG G6 (YouTube). Huawei HUAWEI P10 a P10 Plus. Samsung představil tablet Galaxy Tab S3.

Ladislav Hagara | Komentářů: 1
26.2. 14:00 | Nová verze

Komunita kolem Linuxu From Scratch (LFS) vydala Linux Linux From Scratch 8.0 a Linux From Scratch 8.0 se systemd. Nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů přichází především s Glibc 2.25 a GCC 6.3.0. Současně bylo oznámeno vydání verze 8.0 knih Beyond Linux From Scratch (BLFS) a Beyond Linux From Scratch se systemd.

Ladislav Hagara | Komentářů: 0
26.2. 11:11 | Nová verze

Byla vydána verze 0.10.0 webového prohlížeče qutebrowser (Wikipedie). Přehled novinek v příspěvku na blogu. Vývojáři qutebrowseru kladou důraz na ovladatelnost pomocí klávesnice a minimální GUI. Inspirovali se prohlížečem dwb a rozšířeními pro Firefox Vimperator a Pentadactyl. Prohlížeč qutebrowser je naprogramován v Pythonu a využívá PyQt5. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GNU GPL 3.

Ladislav Hagara | Komentářů: 34
25.2. 16:22 | Nová verze

Po pěti měsících od vydání Waylandu a Westonu 1.12.0 oznámil Bryce Harrington (Samsung) vydání Waylandu 1.13.0 a Westonu 2.0.0.

Ladislav Hagara | Komentářů: 7
24.2. 13:37 | Bezpečnostní upozornění

Společnost Cloudflare (Wikipedie) na svém blogu potvrdila bezpečnostní problém s její službou. V požadovaných odpovědích od reverzní proxy byla odesílána také data z neinicializované paměti. Útočník tak mohl získat cookies, autentizační tokeny, data posílaná přes HTTP POST a další citlivé informace. Jednalo se o chybu v parsování HTML. Zneužitelná byla od 22. září 2016 do 18. února 2017. Seznam webů, kterých se bezpečnostní problém potenciálně týká na GitHubu.

Ladislav Hagara | Komentářů: 1
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 728 hlasů
 Komentářů: 69, poslední dnes 01:02
    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: 693×
    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.