diff options
Diffstat (limited to 'services/app/src/Sql')
| -rw-r--r-- | services/app/src/Sql/Internal/Select.php | 4 | ||||
| -rw-r--r-- | services/app/src/Sql/QueryBuilder.php | 13 |
2 files changed, 13 insertions, 4 deletions
diff --git a/services/app/src/Sql/Internal/Select.php b/services/app/src/Sql/Internal/Select.php index cf3f77a..d5943aa 100644 --- a/services/app/src/Sql/Internal/Select.php +++ b/services/app/src/Sql/Internal/Select.php @@ -33,7 +33,7 @@ final class Select public function __construct( private readonly QueryBuilder $sql, - private readonly string $table, + private readonly string|Select $table, ) { } @@ -94,7 +94,7 @@ final class Select /** * @internal */ - public function _getTable(): string + public function _getTable(): string|Select { return $this->table; } diff --git a/services/app/src/Sql/QueryBuilder.php b/services/app/src/Sql/QueryBuilder.php index 3a5443b..f6aee00 100644 --- a/services/app/src/Sql/QueryBuilder.php +++ b/services/app/src/Sql/QueryBuilder.php @@ -27,7 +27,7 @@ final class QueryBuilder ) { } - public function select(string $table): Select + public function select(string|Select $table): Select { return new Select($this, $table); } @@ -57,6 +57,11 @@ final class QueryBuilder $this->conn->exec($sql); } + public function raw(string $sql): void + { + $this->conn->exec($sql); + } + /** * @internal * @param Select $select @@ -87,7 +92,11 @@ final class QueryBuilder return "SELECT " . implode(', ', $fields) . - " FROM $table" . + ( + $table instanceof Select + ? " FROM (" . $this->compileSelect($table) . ")" + : " FROM $table" + ) . ($join !== null ? " $join->type $join->table ON $join->on" : '') . ($where !== '' ? " WHERE $where" : '') . ( |
