Interfaces

This commit is contained in:
Juan Pablo Vial
2022-09-08 17:40:03 -04:00
parent 803e1a25d3
commit e83638e223
6 changed files with 71 additions and 0 deletions

View File

@ -0,0 +1,8 @@
<?php
namespace ProVM\Concept\Database;
interface Query
{
public function build(): string;
public function __toString(): string;
}

View File

@ -0,0 +1,10 @@
<?php
namespace ProVM\Concept\Database\Query;
use ProVM\Concept\Database\Query;
interface Delete extends Query
{
public function from(string $table): Delete;
public function where(array $conditions): Delete;
}

View File

@ -0,0 +1,12 @@
<?php
namespace ProVM\Concept\Database\Query;
use ProVM\Concept\Database\Query;
interface Insert extends Query
{
public function into(string $table): Insert;
public function columns(array $columns): Insert;
public function values(array $values): Insert;
public function select(Select $select): Insert;
}

View File

@ -0,0 +1,15 @@
<?php
namespace ProVM\Concept\Database\Query;
use ProVM\Concept\Database\Query;
interface Select extends Query
{
public function select(array $columns = ['*']): Select;
public function from(string $table): Select;
public function joins(array $joins): Select;
public function where(array $conditions): Select;
public function groupBy(array $grouping): Select;
public function having(array $having): Select;
public function orderBy(array $ordering): Select;
}

View File

@ -0,0 +1,11 @@
<?php
namespace ProVM\Concept\Database\Query;
use ProVM\Concept\Database\Query;
interface Update extends Query
{
public function table(string $table): Update;
public function set(array $value_pairs): Update;
public function where(array $conditions): Update;
}

View File

@ -0,0 +1,15 @@
<?php
namespace ProVM\Concept\Database;
use Psr\Container\ContainerInterface;
use ProVM\Concept\Database\Query\{Delete,Insert,Select,Update};
interface QueryBuilder
{
public function setContainer(ContainerInterface $container): QueryBuilder;
public function getContainer(): ContainerInterface;
public function select(array $columns = ['*']): Select;
public function insert(string $table): Insert;
public function update(string $table): Update;
public function delete(string $table): Delete;
}