Esempio n. 1
0
 /**
  * {@inheritdoc}
  */
 public function walkInstanceOfExpression($instanceOfExpr)
 {
     $sql = '';
     $dqlAlias = $instanceOfExpr->identificationVariable;
     $discrClass = $class = $this->queryComponents[$dqlAlias]['metadata'];
     if ($class->discriminatorColumn) {
         $discrClass = $this->em->getClassMetadata($class->rootEntityName);
     }
     if ($this->useSqlTableAliases) {
         $sql .= $this->getSQLTableAlias($discrClass->getTableName(), $dqlAlias) . '.';
     }
     $sql .= $class->discriminatorColumn['name'] . ($instanceOfExpr->not ? ' NOT IN ' : ' IN ');
     $sqlParameterList = array();
     foreach ($instanceOfExpr->value as $parameter) {
         if ($parameter instanceof AST\InputParameter) {
             $this->rsm->addMetadataParameterMapping($parameter->name, 'discriminatorValue');
             $sqlParameterList[] = $this->walkInputParameter($parameter);
             continue;
         }
         // Get name from ClassMetadata to resolve aliases.
         $entityClassName = $this->em->getClassMetadata($parameter)->name;
         $discriminatorValue = $class->discriminatorValue;
         if ($entityClassName !== $class->name) {
             $discrMap = array_flip($class->discriminatorMap);
             if (!isset($discrMap[$entityClassName])) {
                 throw QueryException::instanceOfUnrelatedClass($entityClassName, $class->rootEntityName);
             }
             $discriminatorValue = $discrMap[$entityClassName];
         }
         $sqlParameterList[] = $this->conn->quote($discriminatorValue);
     }
     $sql .= '(' . implode(', ', $sqlParameterList) . ')';
     return $sql;
 }