Fixed issue with duplicated commas if Entity has no fields.
This commit is contained in:
parent
f148912a28
commit
6857134f36
@ -510,9 +510,8 @@ class SqlWalker implements TreeWalker
|
|||||||
*/
|
*/
|
||||||
public function walkSelectClause($selectClause)
|
public function walkSelectClause($selectClause)
|
||||||
{
|
{
|
||||||
$sql = 'SELECT ' . (($selectClause->isDistinct) ? 'DISTINCT ' : '') . implode(
|
$sql = 'SELECT ' . (($selectClause->isDistinct) ? 'DISTINCT ' : '');
|
||||||
', ', array_filter(array_map(array($this, 'walkSelectExpression'), $selectClause->selectExpressions))
|
$sqlSelectExpressions = array_filter(array_map(array($this, 'walkSelectExpression'), $selectClause->selectExpressions));
|
||||||
);
|
|
||||||
|
|
||||||
$addMetaColumns = ! $this->_query->getHint(Query::HINT_FORCE_PARTIAL_LOAD) &&
|
$addMetaColumns = ! $this->_query->getHint(Query::HINT_FORCE_PARTIAL_LOAD) &&
|
||||||
$this->_query->getHydrationMode() == Query::HYDRATE_OBJECT
|
$this->_query->getHydrationMode() == Query::HYDRATE_OBJECT
|
||||||
@ -538,7 +537,8 @@ class SqlWalker implements TreeWalker
|
|||||||
$tblAlias = $this->getSQLTableAlias($rootClass->table['name'], $dqlAlias);
|
$tblAlias = $this->getSQLTableAlias($rootClass->table['name'], $dqlAlias);
|
||||||
$discrColumn = $rootClass->discriminatorColumn;
|
$discrColumn = $rootClass->discriminatorColumn;
|
||||||
$columnAlias = $this->getSQLColumnAlias($discrColumn['name']);
|
$columnAlias = $this->getSQLColumnAlias($discrColumn['name']);
|
||||||
$sql .= ", $tblAlias." . $discrColumn['name'] . ' AS ' . $columnAlias;
|
|
||||||
|
$sqlSelectExpressions[] = $tblAlias . '.' . $discrColumn['name'] . ' AS ' . $columnAlias;
|
||||||
|
|
||||||
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
||||||
$this->_rsm->setDiscriminatorColumn($dqlAlias, $columnAlias);
|
$this->_rsm->setDiscriminatorColumn($dqlAlias, $columnAlias);
|
||||||
@ -558,7 +558,9 @@ class SqlWalker implements TreeWalker
|
|||||||
|
|
||||||
foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
|
foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
|
||||||
$columnAlias = $this->getSQLColumnAlias($srcColumn);
|
$columnAlias = $this->getSQLColumnAlias($srcColumn);
|
||||||
$sql .= ", $sqlTableAlias." . $srcColumn . ' AS ' . $columnAlias;
|
|
||||||
|
$sqlSelectExpressions[] = $sqlTableAlias . '.' . $srcColumn . ' AS ' . $columnAlias;
|
||||||
|
|
||||||
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
||||||
$this->_rsm->addMetaResult($dqlAlias, $this->_platform->getSQLResultCasing($columnAlias), $srcColumn, (isset($assoc['id']) && $assoc['id'] === true));
|
$this->_rsm->addMetaResult($dqlAlias, $this->_platform->getSQLResultCasing($columnAlias), $srcColumn, (isset($assoc['id']) && $assoc['id'] === true));
|
||||||
}
|
}
|
||||||
@ -573,7 +575,9 @@ class SqlWalker implements TreeWalker
|
|||||||
if ($assoc['isOwningSide'] && $assoc['type'] & ClassMetadata::TO_ONE) {
|
if ($assoc['isOwningSide'] && $assoc['type'] & ClassMetadata::TO_ONE) {
|
||||||
foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
|
foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
|
||||||
$columnAlias = $this->getSQLColumnAlias($srcColumn);
|
$columnAlias = $this->getSQLColumnAlias($srcColumn);
|
||||||
$sql .= ', ' . $sqlTableAlias . '.' . $srcColumn . ' AS ' . $columnAlias;
|
|
||||||
|
$sqlSelectExpressions[] = $sqlTableAlias . '.' . $srcColumn . ' AS ' . $columnAlias;
|
||||||
|
|
||||||
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
$columnAlias = $this->_platform->getSQLResultCasing($columnAlias);
|
||||||
$this->_rsm->addMetaResult($dqlAlias, $this->_platform->getSQLResultCasing($columnAlias), $srcColumn, (isset($assoc['id']) && $assoc['id'] === true));
|
$this->_rsm->addMetaResult($dqlAlias, $this->_platform->getSQLResultCasing($columnAlias), $srcColumn, (isset($assoc['id']) && $assoc['id'] === true));
|
||||||
}
|
}
|
||||||
@ -582,6 +586,8 @@ class SqlWalker implements TreeWalker
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$sql .= implode(', ', $sqlSelectExpressions);
|
||||||
|
|
||||||
return $sql;
|
return $sql;
|
||||||
}
|
}
|
||||||
|
85
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1225Test.php
Normal file
85
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1225Test.php
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
||||||
|
|
||||||
|
use Doctrine\Common\Collections\ArrayCollection;
|
||||||
|
use Doctrine\Tests\Models\CMS\CmsEmployee;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../../../TestInit.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-1225
|
||||||
|
*/
|
||||||
|
class DDC1225Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||||
|
{
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
try {
|
||||||
|
$this->_schemaTool->createSchema(array(
|
||||||
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\\DDC1225_TestEntity1'),
|
||||||
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\\DDC1225_TestEntity2'),
|
||||||
|
));
|
||||||
|
} catch(\PDOException $e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIssue()
|
||||||
|
{
|
||||||
|
$qb = $this->_em->createQueryBuilder();
|
||||||
|
$qb->from('Doctrine\Tests\ORM\Functional\Ticket\DDC1225_TestEntity1', 'te1')
|
||||||
|
->select('te1')
|
||||||
|
->where('te1.testEntity2 = ?1')
|
||||||
|
->setParameter(1, 0);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
'SELECT t0_.test_entity2_id AS test_entity2_id0 FROM te1 t0_ WHERE t0_.test_entity2_id = ?',
|
||||||
|
$qb->getQuery()->getSQL()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
* @Table(name="te1")
|
||||||
|
*/
|
||||||
|
class DDC1225_TestEntity1
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Id
|
||||||
|
* @ManyToOne(targetEntity="Doctrine\Tests\ORM\Functional\Ticket\DDC1225_TestEntity2")
|
||||||
|
* @JoinColumn(name="test_entity2_id", referencedColumnName="id", nullable=false)
|
||||||
|
*/
|
||||||
|
private $testEntity2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param DDC1225_TestEntity2 $testEntity2
|
||||||
|
*/
|
||||||
|
public function setTestEntity2(DDC1225_TestEntity2 $testEntity2)
|
||||||
|
{
|
||||||
|
$this->testEntity2 = $testEntity2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return DDC1225_TestEntity2
|
||||||
|
*/
|
||||||
|
public function getTestEntity2()
|
||||||
|
{
|
||||||
|
return $this->testEntity2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
* @Table(name="te2")
|
||||||
|
*/
|
||||||
|
class DDC1225_TestEntity2
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Id
|
||||||
|
* @GeneratedValue(strategy="AUTO")
|
||||||
|
* @Column(type="integer")
|
||||||
|
*/
|
||||||
|
private $id;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user