. */ Doctrine::autoload('Doctrine_Relation'); /** * Doctrine_Relation_ForeignKey * This class represents a foreign key relation * * @author Konsta Vesterinen * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @package Doctrine * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ */ class Doctrine_Relation_ForeignKey extends Doctrine_Relation { /** * processDiff * * @param Doctrine_Record $record * @param Doctrine_Connection $conn * @return void */ public function processDiff(Doctrine_Record $record, $conn = null) { if (!$conn) { $conn = $this->getTable()->getConnection(); } $alias = $this->getAlias(); if ($this->isOneToOne()) { if ($record->obtainOriginals($alias) && $record->obtainOriginals($alias)->obtainIdentifier() != $this->obtainReference($alias)->obtainIdentifier() ) { $record->obtainOriginals($alias)->delete($conn); } } else { if ($record->hasReference($alias)) { $new = $record->obtainReference($alias); if ( ! $record->obtainOriginals($alias)) { $record->loadReference($alias); } $operations = Doctrine_Relation::getDeleteOperations($record->obtainOriginals($alias), $new); foreach ($operations as $r) { $r->delete($conn); } $record->assignOriginals($alias, clone $record->get($alias)); } } } /** * fetchRelatedFor * * fetches a component related to given record * * @param Doctrine_Record $record * @return Doctrine_Record|Doctrine_Collection */ public function fetchRelatedFor(Doctrine_Record $record) { $id = $record->get($this->definition['local']); if ($this->isOneToOne()) { if (empty($id)) { $related = $this->getTable()->create(); } else { $dql = 'FROM ' . $this->getTable()->getComponentName() . ' WHERE ' . $this->getTable()->getComponentName() . '.' . $this->definition['foreign'] . ' = ?'; $coll = $this->getTable()->getConnection()->query($dql, array($id)); $related = $coll[0]; } $related->set($this->definition['foreign'], $record, false); } else { if (empty($id)) { $related = new Doctrine_Collection($this->getTable()); } else { $query = $this->getRelationDql(1); $related = $this->getTable()->getConnection()->query($query, array($id)); } $related->setReference($record, $this); } return $related; } }