Portál AbcLinuxu, 12. května 2025 07:46

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: 749×
Odpovědět | Admin
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:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Řešení 1× (DarkKnight)
23.6.2016 13:17 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: Jak získat všechny řádky z MySQL jako objekt
Odpovědět | | Sbalit | Link | Blokovat | Admin
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: 45 | 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: 45 | 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: 45 | 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: 45 | 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: 45 | 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: 45 | 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: 45 | 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, (c) 1999-2007 Stickfish s.r.o.