From 6e7cc432046a7c8a9cfa81ca35f56a751f79c818 Mon Sep 17 00:00:00 2001 From: zYne Date: Tue, 12 Sep 2006 17:40:54 +0000 Subject: [PATCH] added Doctrine_Association_Self --- Doctrine/Association/Self.php | 56 +++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 Doctrine/Association/Self.php 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; + } +} +?>