Commit 5ade9347 authored by Benjamin Eberlei's avatar Benjamin Eberlei

DDC-1266 - Fixed bug where one sequence is dropped multiple times and extended...

DDC-1266 - Fixed bug where one sequence is dropped multiple times and extended that logic to tables and constraints
parent 0b0c41e1
......@@ -42,32 +42,35 @@ use Doctrine\DBAL\Platforms\AbstractPlatform,
class DropSchemaSqlCollector implements Visitor
{
/**
* @var array
* @var \SplObjectStorage
*/
private $_constraints = array();
private $constraints;
/**
* @var array
* @var \SplObjectStorage
*/
private $_sequences = array();
private $sequences;
/**
* @var array
* @var \SplObjectStorage
*/
private $_tables = array();
private $tables;
/**
*
* @var \Doctrine\DBAL\Platforms\AbstractPlatform
*/
private $_platform = null;
private $platform;
/**
* @param AbstractPlatform $platform
*/
public function __construct(AbstractPlatform $platform)
{
$this->_platform = $platform;
$this->platform = $platform;
$this->constraints = new \SplObjectStorage();
$this->sequences = new \SplObjectStorage();
$this->tables = new \SplObjectStorage();
}
/**
......@@ -75,7 +78,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function acceptSchema(Schema $schema)
{
}
/**
......@@ -83,7 +86,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function acceptTable(Table $table)
{
$this->_tables[] = $this->_platform->getDropTableSQL($table->getQuotedName($this->_platform));
$this->tables->attach($table);
}
/**
......@@ -91,7 +94,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function acceptColumn(Table $table, Column $column)
{
}
/**
......@@ -104,7 +107,8 @@ class DropSchemaSqlCollector implements Visitor
throw SchemaException::namedForeignKeyRequired($localTable, $fkConstraint);
}
$this->_constraints[] = $this->_platform->getDropForeignKeySQL($fkConstraint->getQuotedName($this->_platform), $localTable->getQuotedName($this->_platform));
$this->constraints->attach($fkConstraint);
$this->constraints[$fkConstraint] = $localTable;
}
/**
......@@ -113,7 +117,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function acceptIndex(Table $table, Index $index)
{
}
/**
......@@ -121,7 +125,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function acceptSequence(Sequence $sequence)
{
$this->_sequences[] = $this->_platform->getDropSequenceSQL($sequence->getQuotedName($this->_platform));
$this->sequences->attach($sequence);
}
/**
......@@ -129,7 +133,7 @@ class DropSchemaSqlCollector implements Visitor
*/
public function clearQueries()
{
$this->_constraints = $this->_sequences = $this->_tables = array();
$this->constraints = $this->sequences = $this->tables = array();
}
/**
......@@ -137,6 +141,20 @@ class DropSchemaSqlCollector implements Visitor
*/
public function getQueries()
{
return array_merge($this->_constraints, $this->_sequences, $this->_tables);
$sql = array();
foreach ($this->constraints AS $fkConstraint) {
$localTable = $this->constraints[$fkConstraint];
$sql[] = $this->platform->getDropForeignKeySQL($fkConstraint->getQuotedName($this->platform), $localTable->getQuotedName($this->platform));
}
foreach ($this->sequences AS $sequence) {
$sql[] = $this->platform->getDropSequenceSQL($sequence->getQuotedName($this->platform));
}
foreach ($this->tables AS $table) {
$sql[] = $this->platform->getDropTableSQL($table->getQuotedName($this->platform));
}
return $sql;
}
}
Subproject commit 40f1bf16e84ddc5291a6a63aa00b9879c40e3500
Subproject commit d6e4c8b22af9800db4fd9d679ce98538da028168
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment