Fixes for exporting sql to correct connections.
This commit is contained in:
parent
d2d52a63ce
commit
956c5dfe91
@ -977,22 +977,9 @@ class Doctrine_Export extends Doctrine_Connection_Module
|
|||||||
*/
|
*/
|
||||||
public function exportSchema($directory = null)
|
public function exportSchema($directory = null)
|
||||||
{
|
{
|
||||||
$sql = $this->exportSql($directory);
|
$models = Doctrine::loadModels($directory);
|
||||||
|
|
||||||
$this->conn->beginTransaction();
|
$this->exportClasses($models);
|
||||||
|
|
||||||
foreach ($sql as $query) {
|
|
||||||
try {
|
|
||||||
$this->conn->exec($query);
|
|
||||||
} catch (Doctrine_Connection_Exception $e) {
|
|
||||||
// we only want to silence table already exists errors
|
|
||||||
if ($e->getPortableCode() !== Doctrine::ERR_ALREADY_EXISTS) {
|
|
||||||
$this->conn->rollback();
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$this->conn->commit();
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* exportClasses
|
* exportClasses
|
||||||
@ -1005,22 +992,38 @@ class Doctrine_Export extends Doctrine_Connection_Module
|
|||||||
*/
|
*/
|
||||||
public function exportClasses(array $classes)
|
public function exportClasses(array $classes)
|
||||||
{
|
{
|
||||||
$sql = $this->exportClassesSql($classes);
|
$connections = array();
|
||||||
|
foreach ($classes as $class) {
|
||||||
|
$record = new $class();
|
||||||
|
$connection = $record->getTable()->getConnection();
|
||||||
|
$connectionName = Doctrine_Manager::getInstance()->getConnectionName($connection);
|
||||||
|
|
||||||
$this->conn->beginTransaction();
|
if (!isset($connections[$connectionName])) {
|
||||||
|
$connections[$connectionName] = array();
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($sql as $query) {
|
$connections[$connectionName] = array_merge($connections[$connectionName], $this->exportClassesSql(array($class)));
|
||||||
try {
|
}
|
||||||
$this->conn->exec($query);
|
|
||||||
} catch (Doctrine_Connection_Exception $e) {
|
foreach ($connections as $connectionName => $sql) {
|
||||||
// we only want to silence table already exists errors
|
$connection = Doctrine_Manager::getInstance()->getConnection($connectionName);
|
||||||
if ($e->getPortableCode() !== Doctrine::ERR_ALREADY_EXISTS) {
|
|
||||||
$this->conn->rollback();
|
$connection->beginTransaction();
|
||||||
throw $e;
|
|
||||||
|
foreach ($sql as $query) {
|
||||||
|
try {
|
||||||
|
$connection->exec($query);
|
||||||
|
} catch (Doctrine_Connection_Exception $e) {
|
||||||
|
// we only want to silence table already exists errors
|
||||||
|
if ($e->getPortableCode() !== Doctrine::ERR_ALREADY_EXISTS) {
|
||||||
|
$connection->rollback();
|
||||||
|
throw $e;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$connection->commit();
|
||||||
}
|
}
|
||||||
$this->conn->commit();
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* exportClassesSql
|
* exportClassesSql
|
||||||
@ -1050,6 +1053,7 @@ class Doctrine_Export extends Doctrine_Connection_Module
|
|||||||
} else {
|
} else {
|
||||||
$sql[] = $query;
|
$sql[] = $query;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($table->getAttribute(Doctrine::ATTR_EXPORT) & Doctrine::EXPORT_PLUGINS) {
|
if ($table->getAttribute(Doctrine::ATTR_EXPORT) & Doctrine::EXPORT_PLUGINS) {
|
||||||
$sql = array_merge($sql, $this->exportPluginsSql($table));
|
$sql = array_merge($sql, $this->exportPluginsSql($table));
|
||||||
}
|
}
|
||||||
|
@ -134,6 +134,11 @@ END;
|
|||||||
|
|
||||||
$i = 0;
|
$i = 0;
|
||||||
|
|
||||||
|
if (isset($options['inheritance']['extends']) && !isset($options['override_parent'])) {
|
||||||
|
$ret[$i] = "\t\t\t\tparent::setTableDefinition();";
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($options['tableName']) && !empty($options['tableName'])) {
|
if (isset($options['tableName']) && !empty($options['tableName'])) {
|
||||||
$ret[$i] = str_repeat(' ', 8) . '$this->setTableName(\''. $options['tableName'].'\');';
|
$ret[$i] = str_repeat(' ', 8) . '$this->setTableName(\''. $options['tableName'].'\');';
|
||||||
|
|
||||||
@ -188,7 +193,7 @@ END;
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($ret)) {
|
if (!empty($ret)) {
|
||||||
return "\n\t\tpublic function setTableDefinition()"."\n\t\t{\n\t\t\t\tparent::setTableDefinition();\n".implode("\n", $ret)."\n\t\t}";
|
return "\n\t\tpublic function setTableDefinition()"."\n\t\t{\n".implode("\n", $ret)."\n\t\t}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public function buildSetUp(array $options, array $columns, array $relations)
|
public function buildSetUp(array $options, array $columns, array $relations)
|
||||||
@ -197,6 +202,11 @@ END;
|
|||||||
|
|
||||||
$i = 0;
|
$i = 0;
|
||||||
|
|
||||||
|
if (isset($options['inheritance']['extends']) && !isset($options['override_parent'])) {
|
||||||
|
$ret[$i] = "\t\t\t\tparent::setUp();";
|
||||||
|
$i++;
|
||||||
|
}
|
||||||
|
|
||||||
foreach ($relations as $name => $relation) {
|
foreach ($relations as $name => $relation) {
|
||||||
$alias = (isset($relation['alias']) && $relation['alias'] !== $name) ? ' as ' . $relation['alias'] : '';
|
$alias = (isset($relation['alias']) && $relation['alias'] !== $name) ? ' as ' . $relation['alias'] : '';
|
||||||
|
|
||||||
@ -253,7 +263,7 @@ END;
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($ret)) {
|
if (!empty($ret)) {
|
||||||
return "\n\t\tpublic function setUp()\n\t\t{\n\t\t\t\tparent::setUp();\n\t\t\t\t".implode("\n", $ret)."\n\t\t}";
|
return "\n\t\tpublic function setUp()\n\t\t{\n".implode("\n", $ret)."\n\t\t}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -266,8 +276,13 @@ END;
|
|||||||
$className = $options['className'];
|
$className = $options['className'];
|
||||||
$extends = isset($options['inheritance']['extends']) ? $options['inheritance']['extends']:'Doctrine_Record';
|
$extends = isset($options['inheritance']['extends']) ? $options['inheritance']['extends']:'Doctrine_Record';
|
||||||
|
|
||||||
$definition = $this->buildTableDefinition($options, $columns, $relations);
|
if (!isset($options['no_definition'])) {
|
||||||
$setUp = $this->buildSetUp($options, $columns, $relations);
|
$definition = $this->buildTableDefinition($options, $columns, $relations);
|
||||||
|
$setUp = $this->buildSetUp($options, $columns, $relations);
|
||||||
|
} else {
|
||||||
|
$definition = null;
|
||||||
|
$setUp = null;
|
||||||
|
}
|
||||||
|
|
||||||
$content = sprintf(self::$tpl, $className,
|
$content = sprintf(self::$tpl, $className,
|
||||||
$extends,
|
$extends,
|
||||||
@ -298,7 +313,7 @@ END;
|
|||||||
|
|
||||||
if ($this->generateBaseClasses()) {
|
if ($this->generateBaseClasses()) {
|
||||||
|
|
||||||
if (!file_exists($options['fileName'])) {
|
//if (!file_exists($options['fileName'])) {
|
||||||
$optionsBak = $options;
|
$optionsBak = $options;
|
||||||
|
|
||||||
unset($options['tableName']);
|
unset($options['tableName']);
|
||||||
@ -306,7 +321,7 @@ END;
|
|||||||
$this->writeDefinition($options, array(), array());
|
$this->writeDefinition($options, array(), array());
|
||||||
|
|
||||||
$options = $optionsBak;
|
$options = $optionsBak;
|
||||||
}
|
//}
|
||||||
|
|
||||||
$generatedPath = $this->path . DIRECTORY_SEPARATOR . $this->baseClassesDirectory;
|
$generatedPath = $this->path . DIRECTORY_SEPARATOR . $this->baseClassesDirectory;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user