123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- <?php
-
-
- namespace Doctrine\ORM\Persisters;
-
- use Doctrine\ORM\Mapping\ClassMetadata;
-
-
- class SingleTablePersister extends AbstractEntityInheritancePersister
- {
-
- protected function _getDiscriminatorColumnTableName()
- {
- return $this->_class->table['name'];
- }
-
-
- protected function _getSelectColumnListSQL()
- {
- $columnList = parent::_getSelectColumnListSQL();
-
-
- $discrColumn = $this->_class->discriminatorColumn['name'];
- $columnList .= ", $discrColumn";
- $rootClass = $this->_em->getClassMetadata($this->_class->rootEntityName);
- $tableAlias = $this->_getSQLTableAlias($rootClass->name);
- $resultColumnName = $this->_platform->getSQLResultCasing($discrColumn);
- $this->_rsm->setDiscriminatorColumn('r', $resultColumnName);
- $this->_rsm->addMetaResult('r', $resultColumnName, $discrColumn);
-
-
- foreach ($this->_class->subClasses as $subClassName) {
- $subClass = $this->_em->getClassMetadata($subClassName);
-
- foreach ($subClass->fieldMappings as $fieldName => $mapping) {
- if ( ! isset($mapping['inherited'])) {
- $columnList .= ', ' . $this->_getSelectColumnSQL($fieldName, $subClass);
- }
- }
-
- foreach ($subClass->associationMappings as $assoc) {
- if ($assoc['isOwningSide'] && $assoc['type'] & ClassMetadata::TO_ONE && ! isset($assoc['inherited'])) {
- foreach ($assoc['targetToSourceKeyColumns'] as $srcColumn) {
- if ($columnList != '') $columnList .= ', ';
- $columnList .= $this->getSelectJoinColumnSQL($tableAlias, $srcColumn,
- isset($assoc['inherited']) ? $assoc['inherited'] : $this->_class->name
- );
- }
- }
- }
- }
-
- return $columnList;
- }
-
-
- protected function _getInsertColumnList()
- {
- $columns = parent::_getInsertColumnList();
-
- $columns[] = $this->_class->discriminatorColumn['name'];
-
- return $columns;
- }
-
-
- protected function _getSQLTableAlias($className, $assocName = '')
- {
- return parent::_getSQLTableAlias($this->_class->rootEntityName, $assocName);
- }
-
-
- protected function _getSelectConditionSQL(array $criteria, $assoc = null)
- {
- $conditionSql = parent::_getSelectConditionSQL($criteria, $assoc);
-
-
- if ($conditionSql) $conditionSql .= ' AND ';
- $values = array();
- if ($this->_class->discriminatorValue !== null) {
- $values[] = $this->_conn->quote($this->_class->discriminatorValue);
- }
-
- $discrValues = array_flip($this->_class->discriminatorMap);
- foreach ($this->_class->subClasses as $subclassName) {
- $values[] = $this->_conn->quote($discrValues[$subclassName]);
- }
- $conditionSql .= $this->_getSQLTableAlias($this->_class->name) . '.'
- . $this->_class->discriminatorColumn['name']
- . ' IN (' . implode(', ', $values) . ')';
-
- return $conditionSql;
- }
- }
|