1
0
Fork 0
mirror of synced 2025-04-03 13:23:37 +03:00

Refactored Doctrine_Table

This commit is contained in:
zYne 2006-10-24 17:02:47 +00:00
parent 5ed9eeffd7
commit 76b3f2c999
2 changed files with 94 additions and 79 deletions

View file

@ -944,7 +944,7 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* count * count
* this class implements countable interface * this class implements countable interface
* *
* @return integer the number of columns * @return integer the number of columns in this record
*/ */
public function count() { public function count() {
return count($this->_data); return count($this->_data);
@ -952,9 +952,9 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
/** /**
* alias for count() * alias for count()
* *
* @return integer * @return integer the number of columns in this record
*/ */
public function getColumnCount() { public function columnCount() {
return $this->count(); return $this->count();
} }
/** /**
@ -1285,20 +1285,6 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
$this->originals[$name] = clone $coll; $this->originals[$name] = clone $coll;
} }
} }
/**
* filterRelated
* lazy initializes a new filter instance for given related component
*
* @param $componentAlias alias of the related component
* @return Doctrine_Filter
*/
final public function filterRelated($componentAlias) {
if( ! isset($this->filters[$componentAlias])) {
$this->filters[$componentAlias] = new Doctrine_Filter($componentAlias);
}
return $this->filters[$componentAlias];
}
/** /**
* binds One-to-One composite relation * binds One-to-One composite relation
* *
@ -1398,11 +1384,17 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
$this->_table->setTableName($tableName); $this->_table->setTableName($tableName);
} }
public function setInheritanceMap($map) { public function setInheritanceMap($map) {
$this->_table->setInheritanceMap($map); $this->_table->setOption('inheritanceMap', $map);
} }
public function setEnumValues($column, $values) { public function setEnumValues($column, $values) {
$this->_table->setEnumValues($column, $values); $this->_table->setEnumValues($column, $values);
} }
public function option($name, $value = null) {
if($value == null)
$this->_table->getOption($name);
else
$this->_table->setOption($name, $value);
}
/** /**
* addListener * addListener
* *

View file

@ -65,19 +65,9 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
*/ */
private $connection; private $connection;
/** /**
* @var string $name name of the component, for example component name of the GroupTable is 'Group' * @var string $name
*/ */
private $name; private $name;
/**
* @var string $tableName database table name, in most cases this is the same as component name but in some cases
* where one-table-multi-class inheritance is used this will be the name of the inherited table
*/
private $tableName;
/**
* @var string $sequenceName Some databases need sequences instead of auto incrementation primary keys, you can set specific
* sequence for your table by calling setSequenceName()
*/
private $sequenceName;
/** /**
* @var array $identityMap first level cache * @var array $identityMap first level cache
*/ */
@ -87,9 +77,22 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
*/ */
private $repository; private $repository;
/** /**
* @var array $columns an array of column definitions * @var array $columns an array of column definitions,
* keys as column names and values as column definitions
*
* the value array has three values:
*
* the column type, eg. 'integer'
* the column length, eg. 11
* the column options/constraints/validators. eg array('notnull' => true)
*
* so the full columns array might look something like the following:
* array(
* 'name' => array('string', 20, array('notnull' => true, 'default' => 'someone')
* 'age' => array('integer', 11, array('notnull' => true))
* )
*/ */
private $columns = array(); protected $columns = array();
/** /**
* @var array $bound bound relations * @var array $bound bound relations
*/ */
@ -103,23 +106,37 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* determining its state * determining its state
*/ */
private $columnCount; private $columnCount;
/**
* @var array $inheritanceMap inheritanceMap is used for inheritance mapping, keys representing columns and values
* the column values that should correspond to child classes
*/
private $inheritanceMap = array();
/** /**
* @var array $parents the parent classes of this component * @var array $parents the parent classes of this component
*/ */
private $parents = array(); private $parents = array();
/**
* @var array $enum enum value arrays
*/
private $enum = array();
/** /**
* @var boolean $hasDefaultValues whether or not this table has default values * @var boolean $hasDefaultValues whether or not this table has default values
*/ */
private $hasDefaultValues; private $hasDefaultValues;
/**
* @var array $options an array containing all options
*
* -- name name of the component, for example component name of the GroupTable is 'Group'
*
* -- tableName database table name, in most cases this is the same as component name but in some cases
* where one-table-multi-class inheritance is used this will be the name of the inherited table
*
* -- sequenceName Some databases need sequences instead of auto incrementation primary keys,
* you can set specific sequence for your table by calling setOption('sequenceName', $seqName)
* where $seqName is the name of the desired sequence
*
* -- enumMap enum value arrays
*
* -- inheritanceMap inheritanceMap is used for inheritance mapping, keys representing columns and values
* the column values that should correspond to child classes
*/
protected $options = array('name' => null,
'tableName' => null,
'sequenceName' => null,
'inheritanceMap' => array(),
'enumMap' => array(),
);
@ -135,7 +152,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
$this->setParent($this->connection); $this->setParent($this->connection);
$this->name = $name; $this->options['name'] = $name;
if( ! class_exists($name) || empty($name)) if( ! class_exists($name) || empty($name))
throw new Doctrine_Exception("Couldn't find class $name"); throw new Doctrine_Exception("Couldn't find class $name");
@ -168,11 +185,11 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if(isset($this->columns)) { if(isset($this->columns)) {
// get the declaring class of setTableDefinition method // get the declaring class of setTableDefinition method
$method = new ReflectionMethod($this->name,"setTableDefinition"); $method = new ReflectionMethod($this->options['name'],"setTableDefinition");
$class = $method->getDeclaringClass(); $class = $method->getDeclaringClass();
if( ! isset($this->tableName)) if( ! isset($this->options['tableName']))
$this->tableName = Doctrine::tableize($class->getName()); $this->options['tableName'] = Doctrine::tableize($class->getName());
switch(count($this->primaryKeys)): switch(count($this->primaryKeys)):
case 0: case 0:
@ -221,7 +238,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if($this->getAttribute(Doctrine::ATTR_CREATE_TABLES)) { if($this->getAttribute(Doctrine::ATTR_CREATE_TABLES)) {
if(Doctrine_DataDict::isValidClassname($class->getName())) { if(Doctrine_DataDict::isValidClassname($class->getName())) {
$dict = new Doctrine_DataDict($this->getConnection()->getDBH()); $dict = new Doctrine_DataDict($this->getConnection()->getDBH());
$dict->createTable($this->tableName, $this->columns); $dict->createTable($this->options['tableName'], $this->columns);
} }
} }
@ -253,6 +270,20 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
public function getRepository() { public function getRepository() {
return $this->repository; return $this->repository;
} }
public function setOption($name, $value) {
switch($name) {
case 'name':
case 'tableName':
break;
case 'enumMap':
case 'inheritanceMap':
if( ! is_array($value))
throw new Doctrine_Table_Exception($name.' should be an array.');
break;
}
$this->options[$name] = $value;
}
/** /**
* setColumn * setColumn
* @param string $name * @param string $name
@ -361,13 +392,13 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return void * @return void
*/ */
final public function setSequenceName($sequence) { final public function setSequenceName($sequence) {
$this->sequenceName = $sequence; $this->options['sequenceName'] = $sequence;
} }
/** /**
* @return string sequence name * @return string sequence name
*/ */
final public function getSequenceName() { final public function getSequenceName() {
return $this->sequenceName; return $this->options['sequenceName'];
} }
/** /**
* getParents * getParents
@ -379,21 +410,13 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return boolean * @return boolean
*/ */
final public function hasInheritanceMap() { final public function hasInheritanceMap() {
return (empty($this->inheritanceMap)); return (empty($this->options['inheritanceMap']));
}
/**
* setInheritanceMap
* @param array $inheritanceMap
* @return void
*/
final public function setInheritanceMap(array $inheritanceMap) {
$this->inheritanceMap = $inheritanceMap;
} }
/** /**
* @return array inheritance map (array keys as fields) * @return array inheritance map (array keys as fields)
*/ */
final public function getInheritanceMap() { final public function getInheritanceMap() {
return $this->inheritanceMap; return $this->options['inheritanceMap'];
} }
/** /**
* return all composite paths in the form [component1].[component2]. . .[componentN] * return all composite paths in the form [component1].[component2]. . .[componentN]
@ -541,7 +564,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return string the component name * @return string the component name
*/ */
final public function getComponentName() { final public function getComponentName() {
return $this->name; return $this->options['name'];
} }
/** /**
* @return Doctrine_Connection * @return Doctrine_Connection
@ -598,7 +621,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
$table = $this->connection->getTable($name); $table = $this->connection->getTable($name);
if($component == $this->name || in_array($component, $this->parents)) { if($component == $this->options['name'] || in_array($component, $this->parents)) {
// ONE-TO-ONE // ONE-TO-ONE
if($type == Doctrine_Relation::ONE_COMPOSITE || if($type == Doctrine_Relation::ONE_COMPOSITE ||
@ -612,7 +635,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
} elseif($component == $name || } elseif($component == $name ||
($component == $alias)) { // && ($name == $this->name || in_array($name,$this->parents)) ($component == $alias)) { // && ($name == $this->options['name'] || in_array($name,$this->parents))
if( ! isset($local)) if( ! isset($local))
$local = $this->identifier; $local = $this->identifier;
@ -627,7 +650,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if($type != Doctrine_Relation::MANY_AGGREGATE) if($type != Doctrine_Relation::MANY_AGGREGATE)
throw new Doctrine_Table_Exception("Only aggregate relations are allowed for many-to-many relations"); throw new Doctrine_Table_Exception("Only aggregate relations are allowed for many-to-many relations");
$classes = array_merge($this->parents, array($this->name)); $classes = array_merge($this->parents, array($this->options['name']));
foreach(array_reverse($classes) as $class) { foreach(array_reverse($classes) as $class) {
try { try {
@ -676,7 +699,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if($recursive) { if($recursive) {
return $this->getRelation($original, false); return $this->getRelation($original, false);
} else { } else {
throw new Doctrine_Table_Exception($this->name . " doesn't have a relation to " . $original); throw new Doctrine_Table_Exception($this->options['name'] . " doesn't have a relation to " . $original);
} }
} }
/** /**
@ -699,7 +722,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return void * @return void
*/ */
final public function setTableName($name) { final public function setTableName($name) {
$this->tableName = $name; $this->options['tableName'] = $name;
} }
/** /**
@ -708,7 +731,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return string * @return string
*/ */
final public function getTableName() { final public function getTableName() {
return $this->tableName; return $this->options['tableName'];
} }
/** /**
* create * create
@ -720,7 +743,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
public function create(array $array = array()) { public function create(array $array = array()) {
$this->data = $array; $this->data = $array;
$this->isNewEntry = true; $this->isNewEntry = true;
$record = new $this->name($this); $record = new $this->options['name']($this);
$this->isNewEntry = false; $this->isNewEntry = false;
$this->data = array(); $this->data = array();
return $record; return $record;
@ -742,7 +765,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
$query = $this->applyInheritance($query); $query = $this->applyInheritance($query);
$params = array_merge($id, array_values($this->inheritanceMap)); $params = array_merge($id, array_values($this->options['inheritanceMap']));
$stmt = $this->connection->execute($query,$params); $stmt = $this->connection->execute($query,$params);
@ -761,9 +784,9 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return string query where part with column aggregation inheritance added * @return string query where part with column aggregation inheritance added
*/ */
final public function applyInheritance($where) { final public function applyInheritance($where) {
if( ! empty($this->inheritanceMap)) { if( ! empty($this->options['inheritanceMap'])) {
$a = array(); $a = array();
foreach($this->inheritanceMap as $field => $value) { foreach($this->options['inheritanceMap'] as $field => $value) {
$a[] = $field." = ?"; $a[] = $field." = ?";
} }
$i = implode(" AND ",$a); $i = implode(" AND ",$a);
@ -779,7 +802,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
*/ */
public function findAll() { public function findAll() {
$graph = new Doctrine_Query($this->connection); $graph = new Doctrine_Query($this->connection);
$users = $graph->query("FROM ".$this->name); $users = $graph->query("FROM ".$this->options['name']);
return $users; return $users;
} }
/** /**
@ -793,7 +816,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
*/ */
public function findBySql($dql, array $params = array()) { public function findBySql($dql, array $params = array()) {
$q = new Doctrine_Query($this->connection); $q = new Doctrine_Query($this->connection);
$users = $q->query("FROM ".$this->name." WHERE ".$dql, $params); $users = $q->query("FROM ".$this->options['name']." WHERE ".$dql, $params);
return $users; return $users;
} }
@ -836,7 +859,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if(isset($this->identityMap[$id])) if(isset($this->identityMap[$id]))
$record = $this->identityMap[$id]; $record = $this->identityMap[$id];
else { else {
$record = new $this->name($this); $record = new $this->options['name']($this);
$this->identityMap[$id] = $record; $this->identityMap[$id] = $record;
} }
$this->data = array(); $this->data = array();
@ -853,7 +876,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
$query = "SELECT ".implode(", ",$this->primaryKeys)." FROM ".$this->getTableName()." WHERE ".implode(" = ? && ",$this->primaryKeys)." = ?"; $query = "SELECT ".implode(", ",$this->primaryKeys)." FROM ".$this->getTableName()." WHERE ".implode(" = ? && ",$this->primaryKeys)." = ?";
$query = $this->applyInheritance($query); $query = $this->applyInheritance($query);
$params = array_merge(array($id), array_values($this->inheritanceMap)); $params = array_merge(array($id), array_values($this->options['inheritanceMap']));
$this->data = $this->connection->execute($query,$params)->fetch(PDO::FETCH_ASSOC); $this->data = $this->connection->execute($query,$params)->fetch(PDO::FETCH_ASSOC);
@ -875,7 +898,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return integer * @return integer
*/ */
public function count() { public function count() {
$a = $this->connection->getDBH()->query("SELECT COUNT(1) FROM ".$this->tableName)->fetch(PDO::FETCH_NUM); $a = $this->connection->getDBH()->query("SELECT COUNT(1) FROM ".$this->options['tableName'])->fetch(PDO::FETCH_NUM);
return current($a); return current($a);
} }
/** /**
@ -920,15 +943,15 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return void * @return void
*/ */
final public function setEnumValues($field, array $values) { final public function setEnumValues($field, array $values) {
$this->enum[strtolower($field)] = $values; $this->options['enumMap'][strtolower($field)] = $values;
} }
/** /**
* @param string $field * @param string $field
* @return array * @return array
*/ */
final public function getEnumValues($field) { final public function getEnumValues($field) {
if(isset($this->enum[$field])) if(isset($this->options['enumMap'][$field]))
return $this->enum[$field]; return $this->options['enumMap'][$field];
else else
return array(); return array();
} }
@ -940,7 +963,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return mixed * @return mixed
*/ */
final public function enumValue($field, $index) { final public function enumValue($field, $index) {
return isset($this->enum[$field][$index])?$this->enum[$field][$index]:$index; return isset($this->options['enumMap'][$field][$index]) ? $this->options['enumMap'][$field][$index] : $index;
} }
/** /**
* invokeSet * invokeSet
@ -984,10 +1007,10 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @return mixed * @return mixed
*/ */
final public function enumIndex($field, $value) { final public function enumIndex($field, $value) {
if( ! isset($this->enum[$field])) if( ! isset($this->options['enumMap'][$field]))
$values = array(); $values = array();
else else
$values = $this->enum[$field]; $values = $this->options['enumMap'][$field];
return array_search($value, $values); return array_search($value, $values);
} }