[DDC-551] Update SQLWalker to reflect filter requirements for inheritance
This commit is contained in:
parent
efe7a01482
commit
5e91f0c1ca
@ -268,6 +268,11 @@ class SqlWalker implements TreeWalker
|
|||||||
$sqlParts[] = $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
$sqlParts[] = $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add filters on the root class
|
||||||
|
if ('' !== $filterSql = $this->generateFilterConditionSQL($parentClass, $tableAlias)) {
|
||||||
|
$sqlParts[] = $filterSql;
|
||||||
|
}
|
||||||
|
|
||||||
$sql .= implode(' AND ', $sqlParts);
|
$sql .= implode(' AND ', $sqlParts);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,13 +368,35 @@ class SqlWalker implements TreeWalker
|
|||||||
*/
|
*/
|
||||||
private function generateFilterConditionSQL(ClassMetadata $targetEntity, $targetTableAlias)
|
private function generateFilterConditionSQL(ClassMetadata $targetEntity, $targetTableAlias)
|
||||||
{
|
{
|
||||||
$filterClauses = array();
|
if (!$this->_em->hasFilters()) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
if ($this->_em->hasFilters()) {
|
switch($targetEntity->inheritanceType) {
|
||||||
foreach ($this->_em->getFilters()->getEnabledFilters() as $filter) {
|
case ClassMetadata::INHERITANCE_TYPE_NONE:
|
||||||
if ('' !== $filterExpr = $filter->addFilterConstraint($targetEntity, $targetTableAlias)) {
|
break;
|
||||||
$filterClauses[] = '(' . $filterExpr . ')';
|
case ClassMetadata::INHERITANCE_TYPE_JOINED:
|
||||||
|
// The classes in the inheritance will be added to the query one by one,
|
||||||
|
// but only the root node is getting filtered
|
||||||
|
if ($targetEntity->name !== $targetEntity->rootEntityName) {
|
||||||
|
return '';
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case ClassMetadata::INHERITANCE_TYPE_SINGLE_TABLE:
|
||||||
|
// With STI the table will only be queried once, make sure that the filters
|
||||||
|
// are added to the root entity
|
||||||
|
$targetEntity = $this->_em->getClassMetadata($targetEntity->rootEntityName);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
//@todo: throw exception?
|
||||||
|
return '';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$filterClauses = array();
|
||||||
|
foreach ($this->_em->getFilters()->getEnabledFilters() as $filter) {
|
||||||
|
if ('' !== $filterExpr = $filter->addFilterConstraint($targetEntity, $targetTableAlias)) {
|
||||||
|
$filterClauses[] = '(' . $filterExpr . ')';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -519,7 +519,10 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
public function testJoinSubclassPersister_FilterOnlyOnRootTableWhenFetchingSubEntity()
|
public function testJoinSubclassPersister_FilterOnlyOnRootTableWhenFetchingSubEntity()
|
||||||
{
|
{
|
||||||
$this->loadCompanyJoinedSubclassFixtureData();
|
$this->loadCompanyJoinedSubclassFixtureData();
|
||||||
|
// Persister
|
||||||
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyManager')->findAll()));
|
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyManager')->findAll()));
|
||||||
|
// SQLWalker
|
||||||
|
$this->assertEquals(2, count($this->_em->createQuery("SELECT cm FROM Doctrine\Tests\Models\Company\CompanyManager cm")->getResult()));
|
||||||
|
|
||||||
// Enable the filter
|
// Enable the filter
|
||||||
$conf = $this->_em->getConfiguration();
|
$conf = $this->_em->getConfiguration();
|
||||||
@ -531,12 +534,15 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$managers = $this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyManager')->findAll();
|
$managers = $this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyManager')->findAll();
|
||||||
$this->assertEquals(1, count($managers));
|
$this->assertEquals(1, count($managers));
|
||||||
$this->assertEquals("Guilherme", $managers[0]->getName());
|
$this->assertEquals("Guilherme", $managers[0]->getName());
|
||||||
|
|
||||||
|
$this->assertEquals(1, count($this->_em->createQuery("SELECT cm FROM Doctrine\Tests\Models\Company\CompanyManager cm")->getResult()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testJoinSubclassPersister_FilterOnlyOnRootTableWhenFetchingRootEntity()
|
public function testJoinSubclassPersister_FilterOnlyOnRootTableWhenFetchingRootEntity()
|
||||||
{
|
{
|
||||||
$this->loadCompanyJoinedSubclassFixtureData();
|
$this->loadCompanyJoinedSubclassFixtureData();
|
||||||
$this->assertEquals(3, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyPerson')->findAll()));
|
$this->assertEquals(3, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyPerson')->findAll()));
|
||||||
|
$this->assertEquals(3, count($this->_em->createQuery("SELECT cp FROM Doctrine\Tests\Models\Company\CompanyPerson cp")->getResult()));
|
||||||
|
|
||||||
// Enable the filter
|
// Enable the filter
|
||||||
$conf = $this->_em->getConfiguration();
|
$conf = $this->_em->getConfiguration();
|
||||||
@ -548,6 +554,8 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$persons = $this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyPerson')->findAll();
|
$persons = $this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyPerson')->findAll();
|
||||||
$this->assertEquals(1, count($persons));
|
$this->assertEquals(1, count($persons));
|
||||||
$this->assertEquals("Guilherme", $persons[0]->getName());
|
$this->assertEquals("Guilherme", $persons[0]->getName());
|
||||||
|
|
||||||
|
$this->assertEquals(1, count($this->_em->createQuery("SELECT cp FROM Doctrine\Tests\Models\Company\CompanyPerson cp")->getResult()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function loadCompanyJoinedSubclassFixtureData()
|
private function loadCompanyJoinedSubclassFixtureData()
|
||||||
@ -577,7 +585,10 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
public function testSingleTableInheritance_FilterOnlyOnRootTableWhenFetchingSubEntity()
|
public function testSingleTableInheritance_FilterOnlyOnRootTableWhenFetchingSubEntity()
|
||||||
{
|
{
|
||||||
$this->loadCompanySingleTableInheritanceFixtureData();
|
$this->loadCompanySingleTableInheritanceFixtureData();
|
||||||
|
// Persister
|
||||||
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexUltraContract')->findAll()));
|
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexUltraContract')->findAll()));
|
||||||
|
// SQLWalker
|
||||||
|
$this->assertEquals(2, count($this->_em->createQuery("SELECT cfc FROM Doctrine\Tests\Models\Company\CompanyFlexUltraContract cfc")->getResult()));
|
||||||
|
|
||||||
// Enable the filter
|
// Enable the filter
|
||||||
$conf = $this->_em->getConfiguration();
|
$conf = $this->_em->getConfiguration();
|
||||||
@ -586,12 +597,14 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
->enable("completed_contract");
|
->enable("completed_contract");
|
||||||
|
|
||||||
$this->assertEquals(1, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexUltraContract')->findAll()));
|
$this->assertEquals(1, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexUltraContract')->findAll()));
|
||||||
|
$this->assertEquals(1, count($this->_em->createQuery("SELECT cfc FROM Doctrine\Tests\Models\Company\CompanyFlexUltraContract cfc")->getResult()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSingleTableInheritance_FilterOnlyOnRootTableWhenFetchingRootEntity()
|
public function testSingleTableInheritance_FilterOnlyOnRootTableWhenFetchingRootEntity()
|
||||||
{
|
{
|
||||||
$this->loadCompanySingleTableInheritanceFixtureData();
|
$this->loadCompanySingleTableInheritanceFixtureData();
|
||||||
$this->assertEquals(4, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexContract')->findAll()));
|
$this->assertEquals(4, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexContract')->findAll()));
|
||||||
|
$this->assertEquals(4, count($this->_em->createQuery("SELECT cfc FROM Doctrine\Tests\Models\Company\CompanyFlexContract cfc")->getResult()));
|
||||||
|
|
||||||
// Enable the filter
|
// Enable the filter
|
||||||
$conf = $this->_em->getConfiguration();
|
$conf = $this->_em->getConfiguration();
|
||||||
@ -600,6 +613,7 @@ class SQLFilterTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
->enable("completed_contract");
|
->enable("completed_contract");
|
||||||
|
|
||||||
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexContract')->findAll()));
|
$this->assertEquals(2, count($this->_em->getRepository('Doctrine\Tests\Models\Company\CompanyFlexContract')->findAll()));
|
||||||
|
$this->assertEquals(2, count($this->_em->createQuery("SELECT cfc FROM Doctrine\Tests\Models\Company\CompanyFlexContract cfc")->getResult()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function loadCompanySingleTableInheritanceFixtureData()
|
private function loadCompanySingleTableInheritanceFixtureData()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user