本文整理匯總了PHP中Doctrine\DBAL\Schema\Comparator::compareSchemas方法的典型用法代碼示例。如果您正苦於以下問題:PHP Comparator::compareSchemas方法的具體用法?PHP Comparator::compareSchemas怎麽用?PHP Comparator::compareSchemas使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Doctrine\DBAL\Schema\Comparator
的用法示例。
在下文中一共展示了Comparator::compareSchemas方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: testCompareChangedIndexFieldPositions
public function testCompareChangedIndexFieldPositions()
{
$schema1 = new Schema(array('bugdb' => new Table('bugdb', array('integerfield1' => new Column('integerfield1', Type::getType('integer')), 'integerfield2' => new Column('integerfield2', Type::getType('integer'))), array('primary' => new Index('primary', array('integerfield1', 'integerfield2'), true)))));
$schema2 = new Schema(array('bugdb' => new Table('bugdb', array('integerfield1' => new Column('integerfield1', Type::getType('integer')), 'integerfield2' => new Column('integerfield2', Type::getType('integer'))), array('primary' => new Index('primary', array('integerfield2', 'integerfield1'), true)))));
$expected = new SchemaDiff(array(), array('bugdb' => new TableDiff('bugdb', array(), array(), array(), array(), array('primary' => new Index('primary', array('integerfield2', 'integerfield1'), true)))));
$actual = Comparator::compareSchemas($schema1, $schema2);
$this->assertEquals($expected, $actual);
}
示例2: setupSchema
/**
* Creates all required tables from schema if they don't exist
*/
protected function setupSchema(array $files, $clean = false)
{
foreach ($files as $rname => $filepath) {
$this->msg('Using schema from ' . basename($filepath), 1);
$this->status('');
if (($list = (include $filepath)) === false) {
throw new \Aimeos\MW\Setup\Exception(sprintf('Unable to get list from file "%1$s"', $filepath));
}
$dbal = $this->getConnection($rname)->getRawObject();
if (!$dbal instanceof \Doctrine\DBAL\Connection) {
throw new \Aimeos\MW\Setup\Exception('Not a DBAL connection');
}
$dbalschema = new \Doctrine\DBAL\Schema\Schema();
$dbalManager = $dbal->getSchemaManager();
$platform = $dbal->getDatabasePlatform();
$schema = $this->getSchema($rname);
if (isset($list['table'])) {
foreach ((array) $list['table'] as $name => $fcn) {
$this->msg(sprintf('Checking table "%1$s": ', $name), 2);
$table = $dbalManager->listTableDetails($name);
$tables = $table->getColumns() !== array() ? array($table) : array();
$tableSchema = new \Doctrine\DBAL\Schema\Schema($tables);
$schemaDiff = \Doctrine\DBAL\Schema\Comparator::compareSchemas($tableSchema, $fcn(clone $dbalschema));
$stmts = $this->remove($this->exclude($schemaDiff, $list), $clean)->toSaveSql($platform);
$this->executeList($stmts, $rname);
$this->status('done');
}
}
if (isset($list['sequence']) && $schema->supports($schema::HAS_SEQUENCES)) {
$sequences = $dbalManager->listSequences();
foreach ((array) $list['sequence'] as $name => $fcn) {
$this->msg(sprintf('Checking sequence "%1$s": ', $name), 2);
$seqSchema = new \Doctrine\DBAL\Schema\Schema(array(), $sequences);
$schemaDiff = \Doctrine\DBAL\Schema\Comparator::compareSchemas($seqSchema, $fcn(clone $dbalschema));
$stmts = $this->remove($schemaDiff, $clean)->toSaveSql($platform);
$this->executeList($stmts, $rname);
$this->status('done');
}
}
}
}
示例3: migrate
/**
* Migrates the database.
*
* @return Schema
*/
public function migrate()
{
$diff = Comparator::compareSchemas($this->manager->createSchema(), $this->schema);
foreach ($diff->toSaveSql($this->connection->getDatabasePlatform()) as $query) {
$this->connection->executeQuery($query);
}
}
示例4: testCompareChangedBinaryColumn
public function testCompareChangedBinaryColumn()
{
$oldSchema = new Schema();
$tableFoo = $oldSchema->createTable('foo');
$tableFoo->addColumn('id', 'binary');
$newSchema = new Schema();
$table = $newSchema->createTable('foo');
$table->addColumn('id', 'binary', array('length' => 42, 'fixed' => true));
$expected = new SchemaDiff();
$expected->fromSchema = $oldSchema;
$tableDiff = $expected->changedTables['foo'] = new TableDiff('foo');
$tableDiff->fromTable = $tableFoo;
$columnDiff = $tableDiff->changedColumns['id'] = new ColumnDiff('id', $table->getColumn('id'));
$columnDiff->fromColumn = $tableFoo->getColumn('id');
$columnDiff->changedProperties = array('length', 'fixed');
$this->assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema));
}
示例5: testCompareChangedColumn
public function testCompareChangedColumn()
{
$oldSchema = new Schema();
$tableFoo = $oldSchema->createTable('foo');
$tableFoo->addColumn('id', 'integer');
$newSchema = new Schema();
$table = $newSchema->createTable('foo');
$table->addColumn('id', 'string');
$expected = new SchemaDiff();
$expected->fromSchema = $oldSchema;
$tableDiff = $expected->changedTables['foo'] = new TableDiff('foo');
$tableDiff->fromTable = $tableFoo;
$columnDiff = $tableDiff->changedColumns['id'] = new ColumnDiff('id', $table->getColumn('id'));
$columnDiff->fromColumn = $tableFoo->getColumn('id');
$columnDiff->changedProperties = array('type');
$this->assertEquals($expected, Comparator::compareSchemas($oldSchema, $newSchema));
}