2017-06-04 18:00:18 -04:00
|
|
|
<?php
|
2017-11-16 20:23:18 -05:00
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
2017-06-04 18:00:18 -04:00
|
|
|
declare(strict_types=1);
|
2021-04-14 11:17:01 -04:00
|
|
|
|
2017-06-18 10:23:37 -04:00
|
|
|
namespace JKingWeb\Arsse\Misc;
|
2017-06-04 18:00:18 -04:00
|
|
|
|
2022-04-29 16:37:16 -04:00
|
|
|
class Query extends QueryFilter {
|
2017-07-07 11:49:54 -04:00
|
|
|
protected $qBody = ""; // main query body
|
|
|
|
protected $tBody = []; // main query parameter types
|
|
|
|
protected $vBody = []; // main query parameter values
|
2018-12-04 20:41:21 -05:00
|
|
|
protected $group = []; // GROUP BY clause components
|
2017-06-04 18:00:18 -04:00
|
|
|
protected $order = []; // ORDER BY clause components
|
|
|
|
protected $limit = 0;
|
|
|
|
protected $offset = 0;
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function __construct(string $body = "", $types = null, $values = null) {
|
2017-07-07 11:49:54 -04:00
|
|
|
$this->setBody($body, $types, $values);
|
2017-06-04 18:00:18 -04:00
|
|
|
}
|
|
|
|
|
2019-10-18 13:11:03 -04:00
|
|
|
public function setBody(string $body = "", $types = null, $values = null): self {
|
2017-07-07 11:49:54 -04:00
|
|
|
$this->qBody = $body;
|
2017-08-29 10:50:31 -04:00
|
|
|
if (!is_null($types)) {
|
2017-07-07 11:49:54 -04:00
|
|
|
$this->tBody[] = $types;
|
|
|
|
$this->vBody[] = $values;
|
|
|
|
}
|
2019-10-18 13:11:03 -04:00
|
|
|
return $this;
|
2017-07-07 11:49:54 -04:00
|
|
|
}
|
|
|
|
|
2019-10-18 13:11:03 -04:00
|
|
|
public function setGroup(string ...$column): self {
|
2018-12-04 20:41:21 -05:00
|
|
|
foreach ($column as $col) {
|
|
|
|
$this->group[] = $col;
|
|
|
|
}
|
2019-10-18 13:11:03 -04:00
|
|
|
return $this;
|
2018-12-04 20:41:21 -05:00
|
|
|
}
|
|
|
|
|
2019-10-18 13:11:03 -04:00
|
|
|
public function setOrder(string ...$order): self {
|
|
|
|
foreach ($order as $o) {
|
|
|
|
$this->order[] = $o;
|
|
|
|
}
|
|
|
|
return $this;
|
2017-06-04 18:00:18 -04:00
|
|
|
}
|
|
|
|
|
2019-10-18 13:11:03 -04:00
|
|
|
public function setLimit(int $limit, int $offset = 0): self {
|
2017-07-07 11:49:54 -04:00
|
|
|
$this->limit = $limit;
|
|
|
|
$this->offset = $offset;
|
2019-10-18 13:11:03 -04:00
|
|
|
return $this;
|
2017-07-07 11:49:54 -04:00
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function __toString(): string {
|
2022-04-28 21:24:57 -04:00
|
|
|
return $this->buildQueryBody();
|
2017-06-18 10:23:37 -04:00
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function getQuery(): string {
|
2017-07-07 11:49:54 -04:00
|
|
|
return $this->__toString();
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function getTypes(): array {
|
2022-04-29 16:37:16 -04:00
|
|
|
return ValueInfo::flatten([$this->tBody, $this->getWhereTypes()]);
|
2017-07-07 11:49:54 -04:00
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function getValues(): array {
|
2022-04-29 16:37:16 -04:00
|
|
|
return ValueInfo::flatten([$this->vBody, $this->getWhereValues()]);
|
2017-06-18 10:23:37 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function buildQueryBody(): string {
|
|
|
|
$out = "";
|
|
|
|
// add the body
|
2017-07-07 11:49:54 -04:00
|
|
|
$out .= $this->qBody;
|
2017-06-04 18:00:18 -04:00
|
|
|
// add any WHERE terms
|
2019-02-25 22:41:12 -05:00
|
|
|
if (sizeof($this->qWhere) || sizeof($this->qWhereNot)) {
|
2022-04-29 16:37:16 -04:00
|
|
|
$out .= " WHERE ".$this->buildWhereBody();
|
2017-06-04 18:00:18 -04:00
|
|
|
}
|
2018-12-04 20:41:21 -05:00
|
|
|
// add any GROUP BY terms
|
|
|
|
if (sizeof($this->group)) {
|
|
|
|
$out .= " GROUP BY ".implode(", ", $this->group);
|
|
|
|
}
|
2017-06-04 18:00:18 -04:00
|
|
|
// add any ORDER BY terms
|
2017-08-29 10:50:31 -04:00
|
|
|
if (sizeof($this->order)) {
|
2017-06-04 18:00:18 -04:00
|
|
|
$out .= " ORDER BY ".implode(", ", $this->order);
|
|
|
|
}
|
2019-10-18 13:11:03 -04:00
|
|
|
// add LIMIT and OFFSET if either is specified
|
|
|
|
if ($this->limit > 0 || $this->offset > 0) {
|
|
|
|
$out .= " LIMIT ".($this->limit < 1 ? -1 : $this->limit);
|
2017-08-29 10:50:31 -04:00
|
|
|
if ($this->offset > 0) {
|
2017-06-04 18:00:18 -04:00
|
|
|
$out .= " OFFSET ".$this->offset;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $out;
|
|
|
|
}
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|