Diskuze: Výběr pouze potřebných dat z více tabulek ORM
Tvůrce
Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
Ahoj, postni sem kód všech Entit, kterých se výběr týká.
Ahoj,
nebál bych se klidně vybrat celého uživatele, i když z toho nepotřebuješ doslova všechny sloupce.
protected function doCreateQuery(Kdyby\Persistence\Queryable $repository)
{
$qb = $repository->createQueryBuilder()
>select('u')
->from(User::class, 'u');
foreach ($this->filters as $filter) $filter($qb);
return $qb;
}
public function loginUserQuery($username)
{
$this->filters[] = function (QueryBuilder $qb) use ($username){
$qb->innerJoin('u.ban', 'b')
->addSelect('b')
->where('u.name = ?', $username);
};
}
Problém nicméně bude nejspíš v tom, že metoda fetch() vrací ResultSet, čili sadu záznamů. Jestli chceš jen jeden konkrétní záznam, pak zvol metodu fetchOne(), viz https://api.kdyby.org/…ository.html#….
Toto by šlo případně i řešit zápisem přímo v DQL:
$user = $this->em->createQuery("
SELECT user, ban
FROM App\Model\Entities\User user
INNER JOIN user.ban ban
WHERE user.name = :name
")
->setParameter("name", $username)
->setMaxResults(1)
->getOneOrNullResult();
// $user je pak buď instancí App\Model\Entities\User nebo NULL
Ahoj, díky za odpověď. Mohl bych tě poprosit, pokud víš, zvládl bys
napsat ten DQL dotaz pomocí PARTIAL, já se o to snažím podle (http://docs.doctrine-project.org/…objects.html#…), ale
moc mi to nejde. :/
Nakonec to tedy zvolím i pár dat navíc, ale kdybych se mi to někdy hodilo do
budoucna.
No mělo by to fungovat tak, že jen vypíšeš seznam atributů. Mám ale pocit, že musíš vybírat i ID, tzn.:
SELECT PARTIAL user.{id, name, password}
Nejsem si tím ale teď 100% jistý. Pokud chceš neúplný objekt, ale jen pár konkrétních údajů, možná by i bylo lepší to nehydratovat na objekt, ale jen na pole.
Dík moc. Funguje fakt tam stačilo vybrat navíc i id
Zobrazeno 6 zpráv z 6.