Implemented support to entities with association marked as @Id support in many situations. Fixed DDC-1435.
This commit is contained in:
parent
3745e948c6
commit
0ec2cc557f
@ -1111,25 +1111,25 @@ class ClassMetadataInfo implements ClassMetadata
|
|||||||
*/
|
*/
|
||||||
public function getIdentifierColumnNames()
|
public function getIdentifierColumnNames()
|
||||||
{
|
{
|
||||||
if ($this->isIdentifierComposite) {
|
$columnNames = array();
|
||||||
$columnNames = array();
|
|
||||||
foreach ($this->identifier as $idField) {
|
foreach ($this->identifier as $idProperty) {
|
||||||
if (isset($this->associationMappings[$idField])) {
|
if (isset($this->fieldMappings[$idProperty])) {
|
||||||
// no composite pk as fk entity assumption:
|
$columnNames[] = $this->fieldMappings[$idProperty]['columnName'];
|
||||||
$columnNames[] = $this->associationMappings[$idField]['joinColumns'][0]['name'];
|
|
||||||
} else {
|
continue;
|
||||||
$columnNames[] = $this->fieldMappings[$idField]['columnName'];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return $columnNames;
|
|
||||||
} else if(isset($this->fieldMappings[$this->identifier[0]])) {
|
// Association defined as Id field
|
||||||
return array($this->fieldMappings[$this->identifier[0]]['columnName']);
|
$joinColumns = $this->associationMappings[$idProperty]['joinColumns'];
|
||||||
} else {
|
$assocColumnNames = array_map(function ($joinColumn) { return $joinColumn['name']; }, $joinColumns);
|
||||||
// no composite pk as fk entity assumption:
|
|
||||||
return array($this->associationMappings[$this->identifier[0]]['joinColumns'][0]['name']);
|
$columnNames = array_merge($columnNames, $assocColumnNames);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $columnNames;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the type of Id generator to use for the mapped class.
|
* Sets the type of Id generator to use for the mapped class.
|
||||||
*/
|
*/
|
||||||
@ -1904,6 +1904,42 @@ class ClassMetadataInfo implements ClassMetadata
|
|||||||
return $this->name;
|
return $this->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the (possibly quoted) identifier column names for safe use in an SQL statement.
|
||||||
|
*
|
||||||
|
* @param AbstractPlatform $platform
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getQuotedIdentifierColumnNames($platform)
|
||||||
|
{
|
||||||
|
$quotedColumnNames = array();
|
||||||
|
|
||||||
|
foreach ($this->identifier as $idProperty) {
|
||||||
|
if (isset($this->fieldMappings[$idProperty])) {
|
||||||
|
$quotedColumnNames[] = isset($this->fieldMappings[$idProperty]['quoted'])
|
||||||
|
? $platform->quoteIdentifier($this->fieldMappings[$idProperty]['columnName'])
|
||||||
|
: $this->fieldMappings[$idProperty]['columnName'];
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Association defined as Id field
|
||||||
|
$joinColumns = $this->associationMappings[$idProperty]['joinColumns'];
|
||||||
|
$assocQuotedColumnNames = array_map(
|
||||||
|
function ($joinColumn) {
|
||||||
|
return isset($joinColumn['quoted'])
|
||||||
|
? $platform->quoteIdentifier($joinColumn['name'])
|
||||||
|
: $joinColumn['name'];
|
||||||
|
},
|
||||||
|
$joinColumns
|
||||||
|
);
|
||||||
|
|
||||||
|
$quotedColumnNames = array_merge($quotedColumnNames, $assocQuotedColumnNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $quotedColumnNames;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the (possibly quoted) column name of a mapped field for safe use
|
* Gets the (possibly quoted) column name of a mapped field for safe use
|
||||||
* in an SQL statement.
|
* in an SQL statement.
|
||||||
@ -1914,7 +1950,9 @@ class ClassMetadataInfo implements ClassMetadata
|
|||||||
*/
|
*/
|
||||||
public function getQuotedColumnName($field, $platform)
|
public function getQuotedColumnName($field, $platform)
|
||||||
{
|
{
|
||||||
return isset($this->fieldMappings[$field]['quoted']) ? $platform->quoteIdentifier($this->fieldMappings[$field]['columnName']) : $this->fieldMappings[$field]['columnName'];
|
return isset($this->fieldMappings[$field]['quoted'])
|
||||||
|
? $platform->quoteIdentifier($this->fieldMappings[$field]['columnName'])
|
||||||
|
: $this->fieldMappings[$field]['columnName'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -248,10 +248,9 @@ class SqlWalker implements TreeWalker
|
|||||||
$sql .= 'JOIN ' . $parentClass->getQuotedTableName($this->_platform) . ' ' . $tableAlias . ' ON ';
|
$sql .= 'JOIN ' . $parentClass->getQuotedTableName($this->_platform) . ' ' . $tableAlias . ' ON ';
|
||||||
$first = true;
|
$first = true;
|
||||||
|
|
||||||
foreach ($class->identifier as $idField) {
|
foreach ($class->getQuotedIdentifierColumnNames($this->_platform) as $columnName) {
|
||||||
if ($first) $first = false; else $sql .= ' AND ';
|
if ($first) $first = false; else $sql .= ' AND ';
|
||||||
|
|
||||||
$columnName = $class->getQuotedColumnName($idField, $this->_platform);
|
|
||||||
$sql .= $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
$sql .= $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -264,10 +263,9 @@ class SqlWalker implements TreeWalker
|
|||||||
$sql .= ' LEFT JOIN ' . $subClass->getQuotedTableName($this->_platform) . ' ' . $tableAlias . ' ON ';
|
$sql .= ' LEFT JOIN ' . $subClass->getQuotedTableName($this->_platform) . ' ' . $tableAlias . ' ON ';
|
||||||
$first = true;
|
$first = true;
|
||||||
|
|
||||||
foreach ($class->identifier as $idField) {
|
foreach ($class->getQuotedIdentifierColumnNames($this->_platform) as $columnName) {
|
||||||
if ($first) $first = false; else $sql .= ' AND ';
|
if ($first) $first = false; else $sql .= ' AND ';
|
||||||
|
|
||||||
$columnName = $class->getQuotedColumnName($idField, $this->_platform);
|
|
||||||
$sql .= $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
$sql .= $baseTableAlias . '.' . $columnName . ' = ' . $tableAlias . '.' . $columnName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1346,8 +1344,8 @@ class SqlWalker implements TreeWalker
|
|||||||
$tableAlias = $this->getSQLTableAlias($class->getTableName(), $expr);
|
$tableAlias = $this->getSQLTableAlias($class->getTableName(), $expr);
|
||||||
$sqlParts = array();
|
$sqlParts = array();
|
||||||
|
|
||||||
foreach ($class->identifier as $identifier) {
|
foreach ($class->getQuotedIdentifierColumnNames($this->_platform) as $columnName) {
|
||||||
$sqlParts[] = $tableAlias . '.' . $class->getQuotedColumnName($identifier, $this->_platform);
|
$sqlParts[] = $tableAlias . '.' . $columnName;
|
||||||
}
|
}
|
||||||
|
|
||||||
$sql .= implode(', ', $sqlParts);
|
$sql .= implode(', ', $sqlParts);
|
||||||
@ -1634,12 +1632,11 @@ class SqlWalker implements TreeWalker
|
|||||||
$sql .= ' AND ';
|
$sql .= ' AND ';
|
||||||
$first = true;
|
$first = true;
|
||||||
|
|
||||||
foreach ($targetClass->identifier as $idField) {
|
foreach ($targetClass->getQuotedIdentifierColumnNames($this->_platform) as $targetColumnName) {
|
||||||
if ($first) $first = false; else $sql .= ' AND ';
|
if ($first) $first = false; else $sql .= ' AND ';
|
||||||
|
|
||||||
$this->_parserResult->addParameterMapping($dqlParamKey, $this->_sqlParamIndex++);
|
$this->_parserResult->addParameterMapping($dqlParamKey, $this->_sqlParamIndex++);
|
||||||
$sql .= $targetTableAlias . '.'
|
$sql .= $targetTableAlias . '.' . $targetColumnName . ' = ?';
|
||||||
. $targetClass->getQuotedColumnName($idField, $this->_platform) . ' = ?';
|
|
||||||
}
|
}
|
||||||
} else { // many-to-many
|
} else { // many-to-many
|
||||||
$targetClass = $this->_em->getClassMetadata($assoc['targetEntity']);
|
$targetClass = $this->_em->getClassMetadata($assoc['targetEntity']);
|
||||||
@ -1684,12 +1681,11 @@ class SqlWalker implements TreeWalker
|
|||||||
$sql .= ' AND ';
|
$sql .= ' AND ';
|
||||||
$first = true;
|
$first = true;
|
||||||
|
|
||||||
foreach ($targetClass->identifier as $idField) {
|
foreach ($targetClass->getQuotedIdentifierColumnNames($this->_platform) as $targetColumnName) {
|
||||||
if ($first) $first = false; else $sql .= ' AND ';
|
if ($first) $first = false; else $sql .= ' AND ';
|
||||||
|
|
||||||
$this->_parserResult->addParameterMapping($dqlParamKey, $this->_sqlParamIndex++);
|
$this->_parserResult->addParameterMapping($dqlParamKey, $this->_sqlParamIndex++);
|
||||||
$sql .= $targetTableAlias . '.'
|
$sql .= $targetTableAlias . '.' . $targetColumnName . ' = ?';
|
||||||
. $targetClass->getQuotedColumnName($idField, $this->_platform) . ' = ?';
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,6 +9,7 @@ class DDC117Article
|
|||||||
{
|
{
|
||||||
/** @Id @Column(type="integer", name="article_id") @GeneratedValue */
|
/** @Id @Column(type="integer", name="article_id") @GeneratedValue */
|
||||||
private $id;
|
private $id;
|
||||||
|
|
||||||
/** @Column */
|
/** @Column */
|
||||||
private $title;
|
private $title;
|
||||||
|
|
||||||
|
@ -1268,6 +1268,17 @@ class SelectSqlGenerationTest extends \Doctrine\Tests\OrmTestCase
|
|||||||
array(Query::HINT_FORCE_PARTIAL_LOAD => false)
|
array(Query::HINT_FORCE_PARTIAL_LOAD => false)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-1435
|
||||||
|
*/
|
||||||
|
public function testForeignKeyAsPrimaryKeySubselect()
|
||||||
|
{
|
||||||
|
$this->assertSqlGeneration(
|
||||||
|
"SELECT s FROM Doctrine\Tests\Models\DDC117\DDC117Article s WHERE EXISTS (SELECT r FROM Doctrine\Tests\Models\DDC117\DDC117Reference r WHERE r.source = s)",
|
||||||
|
"SELECT d0_.article_id AS article_id0, d0_.title AS title1 FROM DDC117Article d0_ WHERE EXISTS (SELECT d1_.source_id, d1_.target_id FROM DDC117Reference d1_ WHERE d1_.source_id = d0_.article_id)"
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user