當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Comparator::compareSchemas方法代碼示例

本文整理匯總了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);
 }
開發者ID:llinder,項目名稱:FrameworkBenchmarks,代碼行數:8,代碼來源:ComparatorTest.php

示例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');
             }
         }
     }
 }
開發者ID:aimeos,項目名稱:aimeos-core,代碼行數:44,代碼來源:TablesCreateMShop.php

示例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);
     }
 }
開發者ID:pagekit,項目名稱:pagekit,代碼行數:12,代碼來源:Utility.php

示例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));
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:17,代碼來源:ComparatorTest.php

示例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));
 }
開發者ID:pnaq57,項目名稱:zf2demo,代碼行數:17,代碼來源:ComparatorTest.php


注:本文中的Doctrine\DBAL\Schema\Comparator::compareSchemas方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。