Merge pull request #133 from FabioBatSilva/DDC-1335
Fixes DDC-1335. Patch looks perfect to me. @beberlei please merge into 2.1 =)
This commit is contained in:
commit
80284a273d
3 changed files with 251 additions and 8 deletions
|
@ -34,27 +34,55 @@ namespace Doctrine\ORM\Query\Expr;
|
||||||
*/
|
*/
|
||||||
class From
|
class From
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
private $_from;
|
private $_from;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
private $_alias;
|
private $_alias;
|
||||||
|
|
||||||
public function __construct($from, $alias)
|
/**
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $_indexBy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $from The class name.
|
||||||
|
* @param string $alias The alias of the class.
|
||||||
|
* @param string $indexBy The index for the from.
|
||||||
|
*/
|
||||||
|
public function __construct($from, $alias, $indexBy = null)
|
||||||
{
|
{
|
||||||
$this->_from = $from;
|
$this->_from = $from;
|
||||||
$this->_alias = $alias;
|
$this->_alias = $alias;
|
||||||
|
$this->_indexBy = $indexBy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
public function getFrom()
|
public function getFrom()
|
||||||
{
|
{
|
||||||
return $this->_from;
|
return $this->_from;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
public function getAlias()
|
public function getAlias()
|
||||||
{
|
{
|
||||||
return $this->_alias;
|
return $this->_alias;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
public function __toString()
|
public function __toString()
|
||||||
{
|
{
|
||||||
return $this->_from . ' ' . $this->_alias;
|
return $this->_from . ' ' . $this->_alias .
|
||||||
|
($this->_indexBy ? ' INDEX BY ' . $this->_indexBy : '');
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -595,11 +595,12 @@ class QueryBuilder
|
||||||
*
|
*
|
||||||
* @param string $from The class name.
|
* @param string $from The class name.
|
||||||
* @param string $alias The alias of the class.
|
* @param string $alias The alias of the class.
|
||||||
|
* @param string $indexBy The index for the from.
|
||||||
* @return QueryBuilder This QueryBuilder instance.
|
* @return QueryBuilder This QueryBuilder instance.
|
||||||
*/
|
*/
|
||||||
public function from($from, $alias)
|
public function from($from, $alias, $indexBy = null)
|
||||||
{
|
{
|
||||||
return $this->add('from', new Expr\From($from, $alias), true);
|
return $this->add('from', new Expr\From($from, $alias, $indexBy), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
214
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1335Test.php
Normal file
214
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1335Test.php
Normal file
|
@ -0,0 +1,214 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
||||||
|
|
||||||
|
use DateTime;
|
||||||
|
|
||||||
|
require_once __DIR__ . '/../../../TestInit.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-1135
|
||||||
|
*/
|
||||||
|
class DDC1135Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||||
|
{
|
||||||
|
protected function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
try {
|
||||||
|
$this->_schemaTool->createSchema(array(
|
||||||
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC1135User'),
|
||||||
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\DDC1135Phone'),
|
||||||
|
));
|
||||||
|
$this->loadFixture();
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function testDql()
|
||||||
|
{
|
||||||
|
$dql = 'SELECT u FROM ' . __NAMESPACE__ . '\DDC1135User u INDEX BY u.id';
|
||||||
|
$query = $this->_em->createQuery($dql);
|
||||||
|
$result = $query->getResult();
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result), 3);
|
||||||
|
$this->assertArrayHasKey(1, $result);
|
||||||
|
$this->assertArrayHasKey(2, $result);
|
||||||
|
$this->assertArrayHasKey(3, $result);
|
||||||
|
|
||||||
|
$dql = 'SELECT u, p FROM '.__NAMESPACE__ . '\DDC1135User u INDEX BY u.email INNER JOIN u.phones p INDEX BY p.id';
|
||||||
|
$query = $this->_em->createQuery($dql);
|
||||||
|
$result = $query->getResult();
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result), 3);
|
||||||
|
$this->assertArrayHasKey('foo@foo.com', $result);
|
||||||
|
$this->assertArrayHasKey('bar@bar.com', $result);
|
||||||
|
$this->assertArrayHasKey('foobar@foobar.com', $result);
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result['foo@foo.com']->phones), 3);
|
||||||
|
$this->assertEquals(sizeof($result['bar@bar.com']->phones), 3);
|
||||||
|
$this->assertEquals(sizeof($result['foobar@foobar.com']->phones), 3);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(1, $result['foo@foo.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(2, $result['foo@foo.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(3, $result['foo@foo.com']->phones->toArray());
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(4, $result['bar@bar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(5, $result['bar@bar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(6, $result['bar@bar.com']->phones->toArray());
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(7, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(8, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(9, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testTicket()
|
||||||
|
{
|
||||||
|
$builder = $this->_em->createQueryBuilder();
|
||||||
|
$builder->select('u')->from(__NAMESPACE__ . '\DDC1135User', 'u', 'u.id');
|
||||||
|
|
||||||
|
$dql = $builder->getQuery()->getDQL();
|
||||||
|
$result = $builder->getQuery()->getResult();
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result), 3);
|
||||||
|
$this->assertArrayHasKey(1, $result);
|
||||||
|
$this->assertArrayHasKey(2, $result);
|
||||||
|
$this->assertArrayHasKey(3, $result);
|
||||||
|
$this->assertEquals('SELECT u FROM ' . __NAMESPACE__ . '\DDC1135User u INDEX BY u.id', $dql);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndexByUnique()
|
||||||
|
{
|
||||||
|
$builder = $this->_em->createQueryBuilder();
|
||||||
|
$builder->select('u')->from(__NAMESPACE__ . '\DDC1135User', 'u', 'u.email');
|
||||||
|
|
||||||
|
$dql = $builder->getQuery()->getDQL();
|
||||||
|
$result = $builder->getQuery()->getResult();
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result), 3);
|
||||||
|
$this->assertArrayHasKey('foo@foo.com', $result);
|
||||||
|
$this->assertArrayHasKey('bar@bar.com', $result);
|
||||||
|
$this->assertArrayHasKey('foobar@foobar.com', $result);
|
||||||
|
$this->assertEquals('SELECT u FROM ' . __NAMESPACE__ . '\DDC1135User u INDEX BY u.email', $dql);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testIndexWithJoin()
|
||||||
|
{
|
||||||
|
$builder = $this->_em->createQueryBuilder();
|
||||||
|
$builder->select('u','p')
|
||||||
|
->from(__NAMESPACE__ . '\DDC1135User', 'u', 'u.email')
|
||||||
|
->join('u.phones', 'p', null, null, 'p.id');
|
||||||
|
|
||||||
|
$dql = $builder->getQuery()->getDQL();
|
||||||
|
$result = $builder->getQuery()->getResult();
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result), 3);
|
||||||
|
$this->assertArrayHasKey('foo@foo.com', $result);
|
||||||
|
$this->assertArrayHasKey('bar@bar.com', $result);
|
||||||
|
$this->assertArrayHasKey('foobar@foobar.com', $result);
|
||||||
|
|
||||||
|
$this->assertEquals(sizeof($result['foo@foo.com']->phones), 3);
|
||||||
|
$this->assertEquals(sizeof($result['bar@bar.com']->phones), 3);
|
||||||
|
$this->assertEquals(sizeof($result['foobar@foobar.com']->phones), 3);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(1, $result['foo@foo.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(2, $result['foo@foo.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(3, $result['foo@foo.com']->phones->toArray());
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(4, $result['bar@bar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(5, $result['bar@bar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(6, $result['bar@bar.com']->phones->toArray());
|
||||||
|
|
||||||
|
$this->assertArrayHasKey(7, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(8, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
$this->assertArrayHasKey(9, $result['foobar@foobar.com']->phones->toArray());
|
||||||
|
|
||||||
|
$this->assertEquals('SELECT u, p FROM '.__NAMESPACE__ . '\DDC1135User u INDEX BY u.email INNER JOIN u.phones p INDEX BY p.id', $dql);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function loadFixture()
|
||||||
|
{
|
||||||
|
$p1 = array('11 xxxx-xxxx','11 yyyy-yyyy','11 zzzz-zzzz');
|
||||||
|
$p2 = array('22 xxxx-xxxx','22 yyyy-yyyy','22 zzzz-zzzz');
|
||||||
|
$p3 = array('33 xxxx-xxxx','33 yyyy-yyyy','33 zzzz-zzzz');
|
||||||
|
|
||||||
|
$u1 = new DDC1135User("foo@foo.com", "Foo",$p1);
|
||||||
|
$u2 = new DDC1135User("bar@bar.com", "Bar",$p2);
|
||||||
|
$u3 = new DDC1135User("foobar@foobar.com", "Foo Bar",$p3);
|
||||||
|
|
||||||
|
$this->_em->persist($u1);
|
||||||
|
$this->_em->persist($u2);
|
||||||
|
$this->_em->persist($u3);
|
||||||
|
$this->_em->flush();
|
||||||
|
$this->_em->clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
*/
|
||||||
|
class DDC1135User
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Id @Column(type="integer")
|
||||||
|
* @GeneratedValue
|
||||||
|
*/
|
||||||
|
public $id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Column(type="string", unique=true)
|
||||||
|
*/
|
||||||
|
public $email;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Column(type="string")
|
||||||
|
*/
|
||||||
|
public $name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @OneToMany(targetEntity="DDC1135Phone", mappedBy="user", cascade={"persist", "remove"})
|
||||||
|
*/
|
||||||
|
public $phones;
|
||||||
|
|
||||||
|
public function __construct($email, $name, array $numbers = array())
|
||||||
|
{
|
||||||
|
$this->name = $name;
|
||||||
|
$this->email = $email;
|
||||||
|
$this->phones = new \Doctrine\Common\Collections\ArrayCollection();
|
||||||
|
|
||||||
|
foreach ($numbers as $number) {
|
||||||
|
$this->phones->add(new DDC1135Phone($this,$number));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
*/
|
||||||
|
class DDC1135Phone
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Id
|
||||||
|
* @Column(name="id", type="integer")
|
||||||
|
* @GeneratedValue(strategy="AUTO")
|
||||||
|
*/
|
||||||
|
public $id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Column(name="number", type="string", nullable = false)
|
||||||
|
*/
|
||||||
|
public $number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ManyToOne(targetEntity="DDC1135User", inversedBy="phones")
|
||||||
|
* @JoinColumn(name="user_id", referencedColumnName="id", nullable = false)
|
||||||
|
*/
|
||||||
|
public $user;
|
||||||
|
|
||||||
|
public function __construct($user, $number)
|
||||||
|
{
|
||||||
|
$this->user = $user;
|
||||||
|
$this->number = $number;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue