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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 01:02 | Zajímavý článek

Minulý týden byly vydány verze 1.2.3 a 1.1.7 webového poštovního klienta Roundcube. V oznámení o vydání bylo zmíněno řešení bezpečnostního problému nalezeného společností RIPS a souvisejícího s voláním funkce mail() v PHP. Tento týden byly zveřejněny podrobnosti. Útočník mohl pomocí speciálně připraveného emailu spustit na serveru libovolný příkaz. Stejně, jak je popsáno v článku Exploit PHP’s mail() to get remote code execution z roku 2014.

Ladislav Hagara | Komentářů: 0
včera 16:00 | Nová verze

Byla vydána verze 0.98 svobodného nelineárního video editoru Pitivi. Z novinek lze zmínit například přizpůsobitelné klávesové zkratky. Videoukázka práce s nejnovější verzí Pitivi na YouTube.

Ladislav Hagara | Komentářů: 1
včera 15:00 | Zajímavý software

Stop motion je technika animace, při níž je reálný objekt mezi jednotlivými snímky ručně upravován a posouván o malé úseky, tak aby po spojení vyvolala animace dojem spojitosti. Jaký software lze pro stop motion použít na Linuxu? Článek na OMG! Ubuntu! představuje Heron Animation. Ten bohužel podporuje pouze webové kamery. Podpora digitálních zrcadlovek je začleněna například v programu qStopMotion.

Ladislav Hagara | Komentářů: 3
7.12. 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
7.12. 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 2
7.12. 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 6
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 27
6.12. 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 798 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

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

23.6. 12:29 Host
Jak získat všechny řádky z MySQL jako objekt
Přečteno: 678×
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. 13:17 Kit | skóre: 36 | 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. 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. 11:53 Kit | skóre: 36 | 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. 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. 12:35 Kit | skóre: 36 | 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. 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. 12:57 Kit | skóre: 36 | 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. 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. 14:40 Kit | skóre: 36 | 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. 14:50 Kit | skóre: 36 | 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. 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. 16:29 Kit | skóre: 36 | 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. 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. 18:45 Kit | skóre: 36 | 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.