| @@ 5-48 (lines=44) @@ | ||
| 2 | ||
| 3 | namespace BfwSql\Queries\Parts; |
|
| 4 | ||
| 5 | class OrderList extends AbstractList |
|
| 6 | { |
|
| 7 | /** |
|
| 8 | * {@inheritdoc} |
|
| 9 | */ |
|
| 10 | protected $partPrefix = 'ORDER BY'; |
|
| 11 | ||
| 12 | /** |
|
| 13 | * {@inheritdoc} |
|
| 14 | */ |
|
| 15 | protected $separator = ','; |
|
| 16 | ||
| 17 | /** |
|
| 18 | * Magic method __invoke, used when the user call object like a function |
|
| 19 | * @link http://php.net/manual/en/language.oop5.magic.php#object.invoke |
|
| 20 | * |
|
| 21 | * @param string $expr The expression to use into the order |
|
| 22 | * @param string $sort The sort order : ASC or DESC |
|
| 23 | * |
|
| 24 | * @return void |
|
| 25 | */ |
|
| 26 | public function __invoke(string $expr, $sort = 'ASC') |
|
| 27 | { |
|
| 28 | $this->list[] = new Order($expr, $sort); |
|
| 29 | } |
|
| 30 | ||
| 31 | /** |
|
| 32 | * {@inheritdoc} |
|
| 33 | */ |
|
| 34 | public function generate(): string |
|
| 35 | { |
|
| 36 | $sqlPart = ''; |
|
| 37 | ||
| 38 | foreach ($this->list as $index => $order) { |
|
| 39 | if ($index > 0) { |
|
| 40 | $sqlPart .= $this->separator; |
|
| 41 | } |
|
| 42 | ||
| 43 | $sqlPart .= $order->generate(); |
|
| 44 | } |
|
| 45 | ||
| 46 | return $sqlPart; |
|
| 47 | } |
|
| 48 | } |
|
| 49 | ||
| @@ 5-43 (lines=39) @@ | ||
| 2 | ||
| 3 | namespace BfwSql\Queries\Parts; |
|
| 4 | ||
| 5 | class SubQueryList extends AbstractList |
|
| 6 | { |
|
| 7 | /** |
|
| 8 | * {@inheritdoc} |
|
| 9 | */ |
|
| 10 | protected $separator = ','; |
|
| 11 | ||
| 12 | /** |
|
| 13 | * Magic method __invoke, used when the user call object like a function |
|
| 14 | * @link http://php.net/manual/en/language.oop5.magic.php#object.invoke |
|
| 15 | * |
|
| 16 | * @param string $shortcut The shortcut to use into the request |
|
| 17 | * @param string|\BfwSql\Queries\AbstractQuery $subQuery The sub-query |
|
| 18 | * |
|
| 19 | * @return void |
|
| 20 | */ |
|
| 21 | public function __invoke(string $shortcut, $subQuery) |
|
| 22 | { |
|
| 23 | $this->list[] = new SubQuery($shortcut, $subQuery); |
|
| 24 | } |
|
| 25 | ||
| 26 | /** |
|
| 27 | * {@inheritdoc} |
|
| 28 | */ |
|
| 29 | public function generate(): string |
|
| 30 | { |
|
| 31 | $sqlPart = ''; |
|
| 32 | ||
| 33 | foreach ($this->list as $index => $subQuery) { |
|
| 34 | if ($index > 0) { |
|
| 35 | $sqlPart .= $this->separator; |
|
| 36 | } |
|
| 37 | ||
| 38 | $sqlPart .= $subQuery->generate(); |
|
| 39 | } |
|
| 40 | ||
| 41 | return $sqlPart; |
|
| 42 | } |
|
| 43 | } |
|
| 44 | ||