Extbase - Query Objekt: Unterschied zwischen den Versionen
Aus Wikizone
| Zeile 2: | Zeile 2: | ||
[[Extbase - Sortierung und Abfrage von Objekten]] | [[Extbase - Sortierung und Abfrage von Objekten]] | ||
| + | |||
| + | http://mbless.de/blog/2015/03/05/typo3-extbase-query-methods.html | ||
| + | |||
| + | http://lbrmedia.net/codebase/Eintrag/extbase-query-methods/ | ||
Das Query Object steuert Abfragen auf die Datenbank. Wenn man z.B. findAll() im Controller ausführt, werden die Parameter für die Abfrage aus diesem Objekt geholt. | Das Query Object steuert Abfragen auf die Datenbank. Wenn man z.B. findAll() im Controller ausführt, werden die Parameter für die Abfrage aus diesem Objekt geholt. | ||
Version vom 26. Juni 2015, 15:07 Uhr
Siehe auch:
Extbase - Sortierung und Abfrage von Objekten
http://mbless.de/blog/2015/03/05/typo3-extbase-query-methods.html
http://lbrmedia.net/codebase/Eintrag/extbase-query-methods/
Das Query Object steuert Abfragen auf die Datenbank. Wenn man z.B. findAll() im Controller ausführt, werden die Parameter für die Abfrage aus diesem Objekt geholt.
Beipiele
Beispiel Kommaseparierte Liste für Abfrage
http://www.buero-sonne.de/2014/10/16/mysql-orderby-field-in-extbase.html
/**
* Find by multiple uids using, seperated string and maintain the list order
*
*/
public function findByUidListOrderByList($uidList) {
$uidArray = explode(",", $uidList);
$query = $this->createQuery();
$query->matching(
$query->in('uid', $uidArray),
$query->logicalAnd(
$query->equals('hidden', 0),
$query->equals('deleted', 0)
)
);
$query->setOrderings($this->orderByField('uid', $uidArray));
return $query->execute();
}
/**
* Set the order method
*
*/
protected function orderByField($field, $values) {
$orderings = array();
foreach ($values as $value) {
$orderings["$field={$value}"] = \TYPO3\CMS\Extbase\Persistence\QueryInterface::ORDER_DESCENDING;
}
return $orderings;
}