1
0
mirror of synced 2025-01-18 22:41:43 +03:00

[DDC-551] Update SQLWalker to reflect filter requirements for inheritance

This commit is contained in:
Alexander 2011-12-07 10:02:15 +01:00
parent efe7a01482
commit 5e91f0c1ca
2 changed files with 46 additions and 5 deletions

View File

@ -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 . ')';
} }
} }

View File

@ -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()