Skip to content

Commit

Permalink
Merge pull request #100 from nathandentzau/nathandentzau/join-custom-…
Browse files Browse the repository at this point in the history
…self-column

Allow custom self column in join
  • Loading branch information
nilportugues authored Aug 20, 2018
2 parents a941d33 + 2c2b3ab commit 277e87a
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 20 deletions.
41 changes: 23 additions & 18 deletions src/Manipulation/JoinQuery.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,9 @@

namespace NilPortugues\Sql\QueryBuilder\Manipulation;

use NilPortugues\Sql\QueryBuilder\Syntax\SyntaxFactory;
use NilPortugues\Sql\QueryBuilder\Syntax\Where;
use NilPortugues\Sql\QueryBuilder\Syntax\Column;
use NilPortugues\Sql\QueryBuilder\Syntax\SyntaxFactory;

/**
* Class JoinQuery.
Expand Down Expand Up @@ -70,8 +71,8 @@ public function setTable($table)

/**
* @param string $table
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
* @param string[] $columns
*
* @return Select
Expand All @@ -83,8 +84,8 @@ public function leftJoin($table, $selfColumn = null, $refColumn = null, $columns

/**
* @param string $table
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
* @param string[] $columns
* @param string $joinType
*
Expand All @@ -110,8 +111,8 @@ public function join(

/**
* @param Select $select
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
*
* @return Select
*/
Expand All @@ -121,11 +122,15 @@ public function addJoin(Select $select, $selfColumn, $refColumn)
$table = $select->getTable()->getName();

if (!isset($this->joins[$table])) {
$newColumn = array($selfColumn);
$select->joinCondition()->equals(
$refColumn,
SyntaxFactory::createColumn($newColumn, $this->select->getTable())
);
if (!$selfColumn instanceof Column) {
$newColumn = array($selfColumn);
$selfColumn = SyntaxFactory::createColumn(
$newColumn,
$this->select->getTable()
);
}

$select->joinCondition()->equals($refColumn, $selfColumn);
$this->joins[$table] = $select;
}

Expand All @@ -148,8 +153,8 @@ public function setJoin($isJoin = true)

/**
* @param string $table
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
* @param string[] $columns
*
* @internal param null $selectClass
Expand All @@ -163,8 +168,8 @@ public function rightJoin($table, $selfColumn = null, $refColumn = null, $column

/**
* @param string $table
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
* @param string[] $columns
*
* @return Select
Expand All @@ -176,8 +181,8 @@ public function crossJoin($table, $selfColumn = null, $refColumn = null, $column

/**
* @param string $table
* @param string $selfColumn
* @param string $refColumn
* @param mixed $selfColumn
* @param mixed $refColumn
* @param string[] $columns
*
* @return Select
Expand Down
32 changes: 30 additions & 2 deletions tests/Builder/Syntax/SelectWriterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,10 @@

namespace NilPortugues\Tests\Sql\QueryBuilder\Builder\Syntax;

use NilPortugues\Sql\QueryBuilder\Builder\GenericBuilder;
use NilPortugues\Sql\QueryBuilder\Manipulation\Select;
use NilPortugues\Sql\QueryBuilder\Syntax\Column;
use NilPortugues\Sql\QueryBuilder\Syntax\OrderBy;
use NilPortugues\Sql\QueryBuilder\Manipulation\Select;
use NilPortugues\Sql\QueryBuilder\Builder\GenericBuilder;

/**
* Class SelectWriterTest.
Expand Down Expand Up @@ -356,6 +357,33 @@ public function itShouldBeAbleToDoAJoinWithOrderByOnJoinedTable()
$this->assertSame($expected, $this->writer->write($this->query));
}

/**
* @test
*/
public function itShouldBeAbleToDoAJoinWithCustomColumns()
{
$this->query
->setTable('user')
->setColumns(
array(
'userId' => 'user_id',
'username' => 'name',
'email' => 'email',
'created_at',
)
)
->orderBy('user_id', OrderBy::DESC)
->join('news', 'user_id', 'author_id', array('title', 'body', 'created_at', 'updated_at'))
->orderBy('created_at', OrderBy::DESC)
->join('articles', new Column('news_id', 'article'), new Column('id', 'news'));

$expected = 'SELECT user.user_id AS "userId", user.name AS "username", user.email AS "email", user.created_at,'.
' news.title, news.body, news.created_at, news.updated_at FROM user JOIN news ON (news.author_id ='.
' user.user_id) JOIN articles ON (news.id = article.news_id) ORDER BY user.user_id DESC, news.created_at DESC';

$this->assertSame($expected, $this->writer->write($this->query));
}

/**
* @test
*/
Expand Down

0 comments on commit 277e87a

Please sign in to comment.