diff --git a/Doctrine/Association/Self.php b/Doctrine/Association/Self.php new file mode 100644 index 000000000..ad1b7bbb9 --- /dev/null +++ b/Doctrine/Association/Self.php @@ -0,0 +1,56 @@ +. + */ + +class Doctrine_Association_Self extends Doctrine_Association { + /** + * getRelationDql + * + * @param integer $count + * @return string + */ + public function getRelationDql($count, $context = 'record') { + switch($context): + case "record": + $sub = "SELECT ".$this->foreign. + " FROM ".$this->associationTable->getTableName(). + " WHERE ".$this->local. + " = ?"; + $sub2 = "SELECT ".$this->local. + " FROM ".$this->associationTable->getTableName(). + " WHERE ".$this->foreign. + " = ?"; + + + $dql = "FROM ".$this->table->getComponentName(); + $dql .= ".".$this->associationTable->getComponentName(); + $dql .= " WHERE ".$this->table->getComponentName().".".$this->table->getIdentifier()." IN ($sub)"; + $dql .= " || ".$this->table->getComponentName().".".$this->table->getIdentifier()." IN ($sub2)"; + break; + case "collection": + $sub = substr(str_repeat("?, ", $count),0,-2); + $dql = "FROM ".$this->associationTable->getComponentName().".".$this->table->getComponentName(); + $dql .= " WHERE ".$this->associationTable->getComponentName().".".$this->local." IN ($sub)"; + endswitch; + + return $dql; + } +} +?>