From b6f8d53ff1ed0b113d7faba728e7142734d3caba Mon Sep 17 00:00:00 2001 From: Sander Marechal Date: Tue, 29 Oct 2013 11:10:34 +0100 Subject: [PATCH 1/3] [DDC-2764] Prefix criteria orderBy with rootAlias --- lib/Doctrine/ORM/QueryBuilder.php | 2 +- tests/Doctrine/Tests/ORM/QueryBuilderTest.php | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/Doctrine/ORM/QueryBuilder.php b/lib/Doctrine/ORM/QueryBuilder.php index 294c56c63..0a1554e44 100644 --- a/lib/Doctrine/ORM/QueryBuilder.php +++ b/lib/Doctrine/ORM/QueryBuilder.php @@ -1098,7 +1098,7 @@ class QueryBuilder if ($criteria->getOrderings()) { foreach ($criteria->getOrderings() as $sort => $order) { - $this->addOrderBy($sort, $order); + $this->addOrderBy($this->getRootAlias() . '.' . $sort, $order); } } diff --git a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php index 6975c1510..b18450ded 100644 --- a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php +++ b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php @@ -414,13 +414,16 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase public function testAddCriteriaOrder() { $qb = $this->_em->createQueryBuilder(); + $qb->select('u') + ->from('Doctrine\Tests\Models\CMS\CmsUser', 'u'); + $criteria = new Criteria(); $criteria->orderBy(array('field' => Criteria::DESC)); $qb->addCriteria($criteria); $this->assertCount(1, $orderBy = $qb->getDQLPart('orderBy')); - $this->assertEquals('field DESC', (string) $orderBy[0]); + $this->assertEquals('u.field DESC', (string) $orderBy[0]); } public function testAddCriteriaLimit() From 202039e8530368f618a4b3e9978cc5ff42aed4d0 Mon Sep 17 00:00:00 2001 From: Sander Marechal Date: Fri, 1 Nov 2013 13:19:33 +0100 Subject: [PATCH 2/3] Set rootAlias outside loop --- lib/Doctrine/ORM/QueryBuilder.php | 3 ++- tests/Doctrine/Tests/ORM/QueryBuilderTest.php | 12 +++++++++++- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/lib/Doctrine/ORM/QueryBuilder.php b/lib/Doctrine/ORM/QueryBuilder.php index 0a1554e44..b2b7cf37f 100644 --- a/lib/Doctrine/ORM/QueryBuilder.php +++ b/lib/Doctrine/ORM/QueryBuilder.php @@ -1096,9 +1096,10 @@ class QueryBuilder } } + $rootAlias = $this->getRootAlias(); if ($criteria->getOrderings()) { foreach ($criteria->getOrderings() as $sort => $order) { - $this->addOrderBy($this->getRootAlias() . '.' . $sort, $order); + $this->addOrderBy($rootAlias . '.' . $sort, $order); } } diff --git a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php index b18450ded..ab9c7bd85 100644 --- a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php +++ b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php @@ -402,6 +402,9 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase public function testAddCriteriaWhere() { $qb = $this->_em->createQueryBuilder(); + $qb->select('u') + ->from('Doctrine\Tests\Models\CMS\CmsUser', 'u'); + $criteria = new Criteria(); $criteria->where($criteria->expr()->eq('field', 'value')); @@ -429,6 +432,9 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase public function testAddCriteriaLimit() { $qb = $this->_em->createQueryBuilder(); + $qb->select('u') + ->from('Doctrine\Tests\Models\CMS\CmsUser', 'u'); + $criteria = new Criteria(); $criteria->setFirstResult(2); $criteria->setMaxResults(10); @@ -442,7 +448,11 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase public function testAddCriteriaUndefinedLimit() { $qb = $this->_em->createQueryBuilder(); - $qb->setFirstResult(2)->setMaxResults(10); + $qb->select('u') + ->from('Doctrine\Tests\Models\CMS\CmsUser', 'u') + ->setFirstResult(2) + ->setMaxResults(10); + $criteria = new Criteria(); $qb->addCriteria($criteria); From 35a62e9a05a85ab7b2df5a5bee7b63a517dd76df Mon Sep 17 00:00:00 2001 From: Sander Marechal Date: Fri, 1 Nov 2013 13:43:03 +0100 Subject: [PATCH 3/3] Add rootAlias to Criteria where clauses --- .../ORM/Query/QueryExpressionVisitor.php | 28 ++++++++++++------- lib/Doctrine/ORM/QueryBuilder.php | 4 +-- .../ORM/Query/QueryExpressionVisitorTest.php | 28 +++++++++---------- tests/Doctrine/Tests/ORM/QueryBuilderTest.php | 2 +- 4 files changed, 35 insertions(+), 27 deletions(-) diff --git a/lib/Doctrine/ORM/Query/QueryExpressionVisitor.php b/lib/Doctrine/ORM/Query/QueryExpressionVisitor.php index 2da6fb412..e4af98a94 100644 --- a/lib/Doctrine/ORM/Query/QueryExpressionVisitor.php +++ b/lib/Doctrine/ORM/Query/QueryExpressionVisitor.php @@ -47,6 +47,11 @@ class QueryExpressionVisitor extends ExpressionVisitor Comparison::LTE => Expr\Comparison::LTE ); + /** + * @var string + */ + private $rootAlias; + /** * @var Expr */ @@ -58,10 +63,13 @@ class QueryExpressionVisitor extends ExpressionVisitor private $parameters = array(); /** - * Constructor with internal initialization. + * Constructor + * + * @param string $rootAlias */ - public function __construct() + public function __construct($rootAlias) { + $this->rootAlias = $rootAlias; $this->expr = new Expr(); } @@ -133,38 +141,38 @@ class QueryExpressionVisitor extends ExpressionVisitor switch ($comparison->getOperator()) { case Comparison::IN: $this->parameters[] = $parameter; - return $this->expr->in($comparison->getField(), $placeholder); + return $this->expr->in($this->rootAlias . '.' . $comparison->getField(), $placeholder); case Comparison::NIN: $this->parameters[] = $parameter; - return $this->expr->notIn($comparison->getField(), $placeholder); + return $this->expr->notIn($this->rootAlias . '.' . $comparison->getField(), $placeholder); case Comparison::EQ: case Comparison::IS: if ($this->walkValue($comparison->getValue()) === null) { - return $this->expr->isNull($comparison->getField()); + return $this->expr->isNull($this->rootAlias . '.' . $comparison->getField()); } $this->parameters[] = $parameter; - return $this->expr->eq($comparison->getField(), $placeholder); + return $this->expr->eq($this->rootAlias . '.' . $comparison->getField(), $placeholder); case Comparison::NEQ: if ($this->walkValue($comparison->getValue()) === null) { - return $this->expr->isNotNull($comparison->getField()); + return $this->expr->isNotNull($this->rootAlias . '.' . $comparison->getField()); } $this->parameters[] = $parameter; - return $this->expr->neq($comparison->getField(), $placeholder); + return $this->expr->neq($this->rootAlias . '.' . $comparison->getField(), $placeholder); case Comparison::CONTAINS: $parameter->setValue('%' . $parameter->getValue() . '%', $parameter->getType()); $this->parameters[] = $parameter; - return $this->expr->like($comparison->getField(), $placeholder); + return $this->expr->like($this->rootAlias . '.' . $comparison->getField(), $placeholder); default: $operator = self::convertComparisonOperator($comparison->getOperator()); if ($operator) { $this->parameters[] = $parameter; return new Expr\Comparison( - $comparison->getField(), + $this->rootAlias . '.' . $comparison->getField(), $operator, $placeholder ); diff --git a/lib/Doctrine/ORM/QueryBuilder.php b/lib/Doctrine/ORM/QueryBuilder.php index b2b7cf37f..dba95aa5e 100644 --- a/lib/Doctrine/ORM/QueryBuilder.php +++ b/lib/Doctrine/ORM/QueryBuilder.php @@ -1087,7 +1087,8 @@ class QueryBuilder */ public function addCriteria(Criteria $criteria) { - $visitor = new QueryExpressionVisitor(); + $rootAlias = $this->getRootAlias(); + $visitor = new QueryExpressionVisitor($rootAlias); if ($whereExpression = $criteria->getWhereExpression()) { $this->andWhere($visitor->dispatch($whereExpression)); @@ -1096,7 +1097,6 @@ class QueryBuilder } } - $rootAlias = $this->getRootAlias(); if ($criteria->getOrderings()) { foreach ($criteria->getOrderings() as $sort => $order) { $this->addOrderBy($rootAlias . '.' . $sort, $order); diff --git a/tests/Doctrine/Tests/ORM/Query/QueryExpressionVisitorTest.php b/tests/Doctrine/Tests/ORM/Query/QueryExpressionVisitorTest.php index 5c7a5b776..1761da043 100644 --- a/tests/Doctrine/Tests/ORM/Query/QueryExpressionVisitorTest.php +++ b/tests/Doctrine/Tests/ORM/Query/QueryExpressionVisitorTest.php @@ -47,7 +47,7 @@ class QueryExpressionVisitorTest extends \PHPUnit_Framework_TestCase */ protected function setUp() { - $this->visitor = new QueryExpressionVisitor(); + $this->visitor = new QueryExpressionVisitor('o'); } /** @@ -71,24 +71,24 @@ class QueryExpressionVisitorTest extends \PHPUnit_Framework_TestCase $qb = new QueryBuilder(); return array( - array($cb->eq('field', 'value'), $qb->eq('field', ':field'), new Parameter('field', 'value')), - array($cb->neq('field', 'value'), $qb->neq('field', ':field'), new Parameter('field', 'value')), - array($cb->eq('field', null), $qb->isNull('field')), - array($cb->neq('field', null), $qb->isNotNull('field')), - array($cb->isNull('field'), $qb->isNull('field')), + array($cb->eq('field', 'value'), $qb->eq('o.field', ':field'), new Parameter('field', 'value')), + array($cb->neq('field', 'value'), $qb->neq('o.field', ':field'), new Parameter('field', 'value')), + array($cb->eq('field', null), $qb->isNull('o.field')), + array($cb->neq('field', null), $qb->isNotNull('o.field')), + array($cb->isNull('field'), $qb->isNull('o.field')), - array($cb->gt('field', 'value'), $qb->gt('field', ':field'), new Parameter('field', 'value')), - array($cb->gte('field', 'value'), $qb->gte('field', ':field'), new Parameter('field', 'value')), - array($cb->lt('field', 'value'), $qb->lt('field', ':field'), new Parameter('field', 'value')), - array($cb->lte('field', 'value'), $qb->lte('field', ':field'), new Parameter('field', 'value')), + array($cb->gt('field', 'value'), $qb->gt('o.field', ':field'), new Parameter('field', 'value')), + array($cb->gte('field', 'value'), $qb->gte('o.field', ':field'), new Parameter('field', 'value')), + array($cb->lt('field', 'value'), $qb->lt('o.field', ':field'), new Parameter('field', 'value')), + array($cb->lte('field', 'value'), $qb->lte('o.field', ':field'), new Parameter('field', 'value')), - array($cb->in('field', array('value')), $qb->in('field', ':field'), new Parameter('field', array('value'))), - array($cb->notIn('field', array('value')), $qb->notIn('field', ':field'), new Parameter('field', array('value'))), + array($cb->in('field', array('value')), $qb->in('o.field', ':field'), new Parameter('field', array('value'))), + array($cb->notIn('field', array('value')), $qb->notIn('o.field', ':field'), new Parameter('field', array('value'))), - array($cb->contains('field', 'value'), $qb->like('field', ':field'), new Parameter('field', '%value%')), + array($cb->contains('field', 'value'), $qb->like('o.field', ':field'), new Parameter('field', '%value%')), // Test parameter conversion - array($cb->eq('object.field', 'value'), $qb->eq('object.field', ':object_field'), new Parameter('object_field', 'value')), + array($cb->eq('object.field', 'value'), $qb->eq('o.object.field', ':object_field'), new Parameter('object_field', 'value')), ); } diff --git a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php index ab9c7bd85..6b1936a83 100644 --- a/tests/Doctrine/Tests/ORM/QueryBuilderTest.php +++ b/tests/Doctrine/Tests/ORM/QueryBuilderTest.php @@ -410,7 +410,7 @@ class QueryBuilderTest extends \Doctrine\Tests\OrmTestCase $qb->addCriteria($criteria); - $this->assertEquals('field = :field', (string) $qb->getDQLPart('where')); + $this->assertEquals('u.field = :field', (string) $qb->getDQLPart('where')); $this->assertNotNull($qb->getParameter('field')); }