1
0
mirror of synced 2025-01-19 15:01:40 +03:00

Merge branch 'hotfix/#1086-identifier-type-in-proxies'

Close #1086
This commit is contained in:
Marco Pivetta 2015-01-17 08:15:50 +01:00
commit 6164f17229
4 changed files with 135 additions and 5 deletions

View File

@ -80,13 +80,15 @@ abstract class AbstractEntityInheritancePersister extends BasicEntityPersister
* @param string $tableAlias * @param string $tableAlias
* @param string $joinColumnName * @param string $joinColumnName
* @param string $className * @param string $className
* @param string $type
* *
* @return string * @return string
*/ */
protected function getSelectJoinColumnSQL($tableAlias, $joinColumnName, $className) protected function getSelectJoinColumnSQL($tableAlias, $joinColumnName, $className, $type)
{ {
$columnAlias = $this->getSQLColumnAlias($joinColumnName); $columnAlias = $this->getSQLColumnAlias($joinColumnName);
$this->rsm->addMetaResult('r', $columnAlias, $joinColumnName);
$this->rsm->addMetaResult('r', $columnAlias, $joinColumnName, false, $type);
return $tableAlias . '.' . $joinColumnName . ' AS ' . $columnAlias; return $tableAlias . '.' . $joinColumnName . ' AS ' . $columnAlias;
} }

View File

@ -26,6 +26,7 @@ use Doctrine\DBAL\LockMode;
use Doctrine\DBAL\Types\Type; use Doctrine\DBAL\Types\Type;
use Doctrine\Common\Collections\Criteria; use Doctrine\Common\Collections\Criteria;
use Doctrine\ORM\Utility\PersisterHelper;
/** /**
* The joined subclass persister maps a single entity instance to several tables in the * The joined subclass persister maps a single entity instance to several tables in the
@ -457,7 +458,18 @@ class JoinedSubclassPersister extends AbstractEntityInheritancePersister
? $mapping['inherited'] ? $mapping['inherited']
: $this->class->name; : $this->class->name;
$columnList[] = $this->getSelectJoinColumnSQL($tableAlias, $srcColumn, $className); $targetClass = $this->em->getClassMetadata($mapping['targetEntity']);
$columnList[] = $this->getSelectJoinColumnSQL(
$tableAlias,
$srcColumn,
$className,
PersisterHelper::getTypeOfColumn(
$mapping['sourceToTargetKeyColumns'][$srcColumn],
$targetClass,
$this->em
)
);
} }
} }
@ -495,7 +507,18 @@ class JoinedSubclassPersister extends AbstractEntityInheritancePersister
? $mapping['inherited'] ? $mapping['inherited']
: $subClass->name; : $subClass->name;
$columnList[] = $this->getSelectJoinColumnSQL($tableAlias, $srcColumn, $className); $targetClass = $this->em->getClassMetadata($mapping['targetEntity']);
$columnList[] = $this->getSelectJoinColumnSQL(
$tableAlias,
$srcColumn,
$className,
PersisterHelper::getTypeOfColumn(
$mapping['sourceToTargetKeyColumns'][$srcColumn],
$targetClass,
$this->em
)
);
} }
} }
} }

View File

@ -21,6 +21,7 @@ namespace Doctrine\ORM\Persisters\Entity;
use Doctrine\ORM\Mapping\ClassMetadata; use Doctrine\ORM\Mapping\ClassMetadata;
use Doctrine\Common\Collections\Criteria; use Doctrine\Common\Collections\Criteria;
use Doctrine\ORM\Utility\PersisterHelper;
/** /**
* Persister for entities that participate in a hierarchy mapped with the * Persister for entities that participate in a hierarchy mapped with the
@ -88,7 +89,19 @@ class SingleTablePersister extends AbstractEntityInheritancePersister
foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) { foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
$className = isset($assoc['inherited']) ? $assoc['inherited'] : $this->class->name; $className = isset($assoc['inherited']) ? $assoc['inherited'] : $this->class->name;
$columnList[] = $this->getSelectJoinColumnSQL($tableAlias, $srcColumn, $className);
$targetClass = $this->em->getClassMetadata($mapping['targetEntity']);
$columnList[] = $this->getSelectJoinColumnSQL(
$tableAlias,
$srcColumn,
$className,
PersisterHelper::getTypeOfColumn(
$mapping['sourceToTargetKeyColumns'][$srcColumn],
$targetClass,
$this->em
)
);
} }
} }
} }

View File

@ -0,0 +1,92 @@
<?php
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\Tests\OrmFunctionalTestCase;
/**
* Functional tests for get Id after clone child entity
*
* @author Lallement Thomas <thomas.lallement@9online.fr>
*/
class DDC3223Test extends OrmFunctionalTestCase
{
protected function setUp()
{
parent::setUp();
$this->setUpEntitySchema(array(
'Doctrine\Tests\ORM\Functional\Ticket\Journalist',
'Doctrine\Tests\ORM\Functional\Ticket\Participant',
'Doctrine\Tests\ORM\Functional\Ticket\Status',
'Doctrine\Tests\ORM\Functional\Ticket\ProfileStatus',
));
}
public function testIssueGetId()
{
$profileStatus = new ProfileStatus();
$participant = new Journalist();
$participant->profileStatus = $profileStatus;
$this->_em->persist($profileStatus);
$this->_em->persist($participant);
$this->_em->flush();
$this->_em->clear();
$participant = $this->_em->find('Doctrine\Tests\ORM\Functional\Ticket\Participant', $participant->id);
$profileStatus = clone $participant->profileStatus;
$this->assertSame(1, $profileStatus->getId(), 'The identifier on the cloned instance is an integer');
}
}
/** @Entity @Table(name="ddc3223_journalist") */
class Journalist extends Participant
{
}
/**
* @Entity @Table(name="ddc3223_participant")
* @InheritanceType("JOINED")
* @DiscriminatorColumn(name="discr", type="string")
* @DiscriminatorMap({
* "journalist" = "Journalist",
* })
*/
class Participant
{
/** @Id @Column(type="integer") @GeneratedValue */
public $id;
/** @ManyToOne(targetEntity="ProfileStatus") */
public $profileStatus;
}
/**
* @Entity @Table(name="ddc3223_status")
* @InheritanceType("SINGLE_TABLE")
* @DiscriminatorColumn(name="discr", type="string")
* @DiscriminatorMap({
* "profile" = "ProfileStatus",
* })
*/
class Status
{
/** @Id @Column(type="integer") @GeneratedValue(strategy="AUTO") */
private $id;
public function getId()
{
return $this->id;
}
}
/**
* @Entity
*/
class ProfileStatus extends Status
{
}