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


PHP SchemaTool::getSchemaFromMetadata方法代碼示例

本文整理匯總了PHP中Doctrine\ORM\Tools\SchemaTool::getSchemaFromMetadata方法的典型用法代碼示例。如果您正苦於以下問題:PHP SchemaTool::getSchemaFromMetadata方法的具體用法?PHP SchemaTool::getSchemaFromMetadata怎麽用?PHP SchemaTool::getSchemaFromMetadata使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Doctrine\ORM\Tools\SchemaTool的用法示例。


在下文中一共展示了SchemaTool::getSchemaFromMetadata方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: updateDbSchema

 /**
  * Updates DB Schema.
  * @throws \Exception if there are no changes in entities
  */
 protected function updateDbSchema()
 {
     /**
      * @var $em \Doctrine\ORM\EntityManager
      */
     $em = $this->getContainer()->get('doctrine.orm.entity_manager');
     $event = $em->getEventManager();
     $sm = $em->getConnection()->getSchemaManager();
     $allMetadata = $em->getMetadataFactory()->getAllMetadata();
     $schemaTool = new SchemaTool($em);
     $entitiesMetadata = array($em->getClassMetadata(ApiUser::getClassName()), $em->getClassMetadata(DiamanteUser::getClassName()));
     $event->disableListeners();
     $currentSchema = $sm->createSchema();
     $schemaFromMetadata = $schemaTool->getSchemaFromMetadata($allMetadata);
     $entitiesSchema = $schemaTool->getSchemaFromMetadata($entitiesMetadata);
     $entitiesTables = $entitiesSchema->getTables();
     $entitiesTableName = array_keys($entitiesTables);
     $currentDiamanteSchema = $this->getTargetSchema($currentSchema, $entitiesTableName);
     $diamanteSchemaFromMetadata = $this->getTargetSchema($schemaFromMetadata, $entitiesTableName);
     $comparator = new Comparator();
     $diff = $comparator->compare($currentDiamanteSchema, $diamanteSchemaFromMetadata);
     $toUpdate = $diff->toSql($em->getConnection()->getDatabasePlatform());
     if (empty($toUpdate)) {
         throw new \Exception('No new updates found. Diamante Api Bundle is up to date!');
     }
     $conn = $em->getConnection();
     foreach ($toUpdate as $sql) {
         $conn->executeQuery($sql);
     }
 }
開發者ID:gitter-badger,項目名稱:diamantedesk-application,代碼行數:34,代碼來源:SchemaCommand.php

示例2: updateDbSchema

 /**
  * Updates DB Schema. Changes from Diamante only will be applied for current schema. Other bundles updating skips
  * @throws \Exception if there are no changes in entities
  */
 protected function updateDbSchema()
 {
     /**
      * @var $em \Doctrine\ORM\EntityManager
      */
     $em = $this->getContainer()->get('doctrine.orm.entity_manager');
     $event = $em->getEventManager();
     $sm = $em->getConnection()->getSchemaManager();
     $allMetadata = $em->getMetadataFactory()->getAllMetadata();
     $schemaTool = new SchemaTool($em);
     $entitiesMetadata = array($em->getClassMetadata(\Diamante\DeskBundle\Entity\Branch::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\Ticket::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\Comment::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\Attachment::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\BranchEmailConfiguration::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\MessageReference::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\TicketHistory::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\WatcherList::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\TicketTimeline::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\Audit::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\AuditField::getClassName()), $em->getClassMetadata(\Diamante\DeskBundle\Entity\Article::getClassName()));
     $event->disableListeners();
     $currentSchema = $sm->createSchema();
     $schemaFromMetadata = $schemaTool->getSchemaFromMetadata($allMetadata);
     $entitiesSchema = $schemaTool->getSchemaFromMetadata($entitiesMetadata);
     $entitiesTables = $entitiesSchema->getTables();
     $entitiesTableName = array_keys($entitiesTables);
     $currentDiamanteSchema = $this->getTargetSchema($currentSchema, $entitiesTableName);
     $diamanteSchemaFromMetadata = $this->getTargetSchema($schemaFromMetadata, $entitiesTableName);
     $comparator = new Comparator();
     $diff = $comparator->compare($currentDiamanteSchema, $diamanteSchemaFromMetadata);
     $toUpdate = $diff->toSql($em->getConnection()->getDatabasePlatform());
     if (empty($toUpdate)) {
         throw new \Exception('No new updates found. DiamanteDesk is up to date!');
     }
     $conn = $em->getConnection();
     foreach ($toUpdate as $sql) {
         $conn->executeQuery($sql);
     }
 }
開發者ID:northdakota,項目名稱:diamantedesk-application,代碼行數:34,代碼來源:AbstractCommand.php

示例3: getTaggingSchema

 protected function getTaggingSchema($em)
 {
     $tool = new \Doctrine\ORM\Tools\SchemaTool($em);
     $classes = array($em->getClassMetadata('Poc\\PocPlugins\\Tagging\\Driver\\Doctrine2\\Entities\\Cache'), $em->getClassMetadata('Poc\\PocPlugins\\Tagging\\Driver\\Doctrine2\\Entities\\CacheTag'), $em->getClassMetadata('Poc\\PocPlugins\\Tagging\\Driver\\Doctrine2\\Entities\\Tag'));
     $schema = $tool->getSchemaFromMetadata($classes);
     return $schema;
 }
開發者ID:flyingwhale,項目名稱:poc,代碼行數:7,代碼來源:DbInitCommand.php

示例4: down

 /**
  * Down method
  *
  * @param Schema $schema
  */
 public function down(Schema $schema)
 {
     if (Version::isSupportGetInstanceFunction()) {
         $app = Application::getInstance();
         $meta = $this->getMetadata($app['orm.em']);
         $tool = new SchemaTool($app['orm.em']);
         $schemaFromMetadata = $tool->getSchemaFromMetadata($meta);
         // テーブル削除
         foreach ($schemaFromMetadata->getTables() as $table) {
             if ($schema->hasTable($table->getName())) {
                 $schema->dropTable($table->getName());
             }
         }
         // シーケンス削除
         foreach ($schemaFromMetadata->getSequences() as $sequence) {
             if ($schema->hasSequence($sequence->getName())) {
                 $schema->dropSequence($sequence->getName());
             }
         }
     } else {
         if ($schema->hasTable(self::MAKER)) {
             $schema->dropTable(self::MAKER);
         }
         if ($schema->hasTable(self::PRODUCTMAKER)) {
             $schema->dropTable(self::PRODUCTMAKER);
         }
     }
     if ($this->connection->getDatabasePlatform()->getName() == 'postgresql') {
         foreach ($this->sequence as $sequence) {
             if ($schema->hasSequence($sequence)) {
                 $schema->dropSequence($sequence);
             }
         }
     }
 }
開發者ID:EC-CUBE,項目名稱:maker-plugin,代碼行數:40,代碼來源:Version201507231300.php

示例5: execute

    public function execute(InputInterface $input, OutputInterface $output)
    {
        $configuration = $this->_getMigrationConfiguration($input, $output);

        $em = $this->getHelper('em')->getEntityManager();
        $conn = $em->getConnection();
        $platform = $conn->getDatabasePlatform();
        $metadata = $em->getMetadataFactory()->getAllMetadata();

        if (empty($metadata)) {
            $output->writeln('No mapping information to process.', 'ERROR');
            return;
        }

        $tool = new SchemaTool($em);

        $fromSchema = $conn->getSchemaManager()->createSchema();
        $toSchema = $tool->getSchemaFromMetadata($metadata);
        $up = $this->_buildCodeFromSql($configuration, $fromSchema->getMigrateToSql($toSchema, $platform));
        $down = $this->_buildCodeFromSql($configuration, $fromSchema->getMigrateFromSql($toSchema, $platform));

        if ( ! $up && ! $down) {
            $output->writeln('No changes detected in your mapping information.', 'ERROR');
            return;
        }

        $version = date('YmdHis');
        $path = $this->_generateMigration($configuration, $input, $version, $up, $down);

        $output->writeln(sprintf('Generated new migration class to "<info>%s</info>" from schema differences.', $path));
    }
開發者ID:pmjones,項目名稱:php-framework-benchmarks,代碼行數:31,代碼來源:DiffCommand.php

示例6: down

 /**
  * remove table.
  *
  * @param Schema $schema
  */
 public function down(Schema $schema)
 {
     //current version >= 3.0.9
     if (Version::isSupportGetInstanceFunction()) {
         $app = Application::getInstance();
         $meta = $this->getMetadata($app['orm.em']);
         $tool = new SchemaTool($app['orm.em']);
         $schemaFromMetadata = $tool->getSchemaFromMetadata($meta);
         // テーブル削除
         foreach ($schemaFromMetadata->getTables() as $table) {
             if ($schema->hasTable($table->getName())) {
                 $schema->dropTable($table->getName());
             }
         }
         // シーケンス削除
         foreach ($schemaFromMetadata->getSequences() as $sequence) {
             if ($schema->hasSequence($sequence->getName())) {
                 $schema->dropSequence($sequence->getName());
             }
         }
         //for delete sequence in postgresql
         if ($this->connection->getDatabasePlatform()->getName() == 'postgresql') {
             $schema->dropSequence('plg_related_product_id_seq');
         }
     } else {
         // this down() migration is auto-generated, please modify it to your needs
         $schema->dropTable(self::NAME);
         $schema->dropSequence('plg_related_product_id_seq');
     }
 }
開發者ID:EC-CUBE,項目名稱:related-product-plugin,代碼行數:35,代碼來源:Version20150808173000.php

示例7: down

 /**
  * Remove data.
  *
  * @param Schema $schema
  */
 public function down(Schema $schema)
 {
     if (Version::isSupportGetInstanceFunction()) {
         $app = Application::getInstance();
         $meta = $this->getMetadata($app['orm.em']);
         $tool = new SchemaTool($app['orm.em']);
         $schemaFromMetadata = $tool->getSchemaFromMetadata($meta);
         // テーブル削除
         foreach ($schemaFromMetadata->getTables() as $table) {
             if ($schema->hasTable($table->getName())) {
                 $schema->dropTable($table->getName());
             }
         }
         // シーケンス削除
         foreach ($schemaFromMetadata->getSequences() as $sequence) {
             if ($schema->hasSequence($sequence->getName())) {
                 $schema->dropSequence($sequence->getName());
             }
         }
     } else {
         // this down() migration is auto-generated, please modify it to your needs
         $schema->dropTable(self::NAME);
         $schema->dropSequence('plg_recommend_product_recommend_product_id_seq');
     }
 }
開發者ID:EC-CUBE,項目名稱:Recommend-plugin,代碼行數:30,代碼來源:Version201510211300.php

示例8: testNullDefaultNotAddedToCustomSchemaOptions

 public function testNullDefaultNotAddedToCustomSchemaOptions()
 {
     $em = $this->_getTestEntityManager();
     $schemaTool = new SchemaTool($em);
     $classes = array($em->getClassMetadata('Doctrine\\Tests\\Models\\NullDefault\\NullDefaultColumn'));
     $customSchemaOptions = $schemaTool->getSchemaFromMetadata($classes)->getTable('NullDefaultColumn')->getColumn('nullDefault')->getCustomSchemaOptions();
     $this->assertSame(array(), $customSchemaOptions);
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:8,代碼來源:SchemaToolTest.php

示例9: createSchema

 /**
  * {@inheritdoc}
  */
 public function createSchema()
 {
     $metadata = $this->entityManager->getMetadataFactory()->getAllMetadata();
     if (empty($metadata)) {
         throw new \UnexpectedValueException('No mapping information to process');
     }
     $tool = new SchemaTool($this->entityManager);
     return $tool->getSchemaFromMetadata($metadata);
 }
開發者ID:Dren-x,項目名稱:mobitnew,代碼行數:12,代碼來源:OrmSchemaProvider.php

示例10: testPostGenerateEvents

 /**
  * @group DDC-283
  */
 public function testPostGenerateEvents()
 {
     $listener = new GenerateSchemaEventListener();
     $em = $this->_getTestEntityManager();
     $em->getEventManager()->addEventListener(array(ToolEvents::postGenerateSchemaTable, ToolEvents::postGenerateSchema), $listener);
     $schemaTool = new SchemaTool($em);
     $classes = array($em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsAddress'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsArticle'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsComment'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsEmployee'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsGroup'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsPhonenumber'), $em->getClassMetadata('Doctrine\\Tests\\Models\\CMS\\CmsUser'));
     $schema = $schemaTool->getSchemaFromMetadata($classes);
     $this->assertEquals(count($classes), $listener->tableCalls);
     $this->assertTrue($listener->schemaCalled);
 }
開發者ID:dracony,項目名稱:forked-php-orm-benchmark,代碼行數:14,代碼來源:SchemaToolTest.php

示例11: execute

 /**
  * Generate sql queries and create new migration class
  * 
  * @param InputInterface  $input
  * @param OutputInterface $output
  * 
  * @return null
  * @throws \InvalidArgumentException
  */
 public function execute(\Symfony\Component\Console\Input\InputInterface $input, \Symfony\Component\Console\Output\OutputInterface $output)
 {
     $isDbalOld = DbalVersion::compare('2.2.0') > 0;
     $configuration = $this->getMigrationConfiguration($input, $output);
     $em = $this->getHelper('em')->getEntityManager();
     $conn = $em->getConnection();
     $platform = $conn->getDatabasePlatform();
     $metadata = $em->getMetadataFactory()->getAllMetadata();
     if (empty($metadata)) {
         $output->writeln('No mapping information to process.', 'ERROR');
         return;
     }
     if ($filterExpr = $input->getOption('filter-expression')) {
         if ($isDbalOld) {
             throw new \InvalidArgumentException('The "--filter-expression" option can only be used as of Doctrine DBAL 2.2');
         }
         $conn->getConfiguration()->setFilterSchemaAssetsExpression($filterExpr);
     }
     $tool = new SchemaTool($em);
     $fromSchema = $conn->getSchemaManager()->createSchema();
     $toSchema = $tool->getSchemaFromMetadata($metadata);
     foreach ($fromSchema->getTables() as $tableName => $table) {
         if (!$toSchema->hasTable($tableName)) {
             // if drop the table from the $fromSchema, could not generate the DROP TABLE sql
             $fromSchema->dropTable($tableName);
         }
     }
     //Not using value from options, because filters can be set from config.yml
     if (!$isDbalOld && ($filterExpr = $conn->getConfiguration()->getFilterSchemaAssetsExpression())) {
         $tableNames = $toSchema->getTableNames();
         foreach ($tableNames as $tableName) {
             $tableName = substr($tableName, strpos($tableName, '.') + 1);
             if (!preg_match($filterExpr, $tableName)) {
                 $toSchema->dropTable($tableName);
             }
         }
     }
     $up = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateToSql($toSchema, $platform));
     $down = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateFromSql($toSchema, $platform));
     if (!$up && !$down) {
         $output->writeln('No changes detected in your mapping information.', 'ERROR');
         return;
     }
     $version = date('YmdHis');
     $path = $this->generateMigration($configuration, $input, $version, $up, $down);
     $output->writeln(sprintf('Generated new migration class to "<info>%s</info>" from schema differences.', $path));
 }
開發者ID:nahakiole,項目名稱:cloudrexx,代碼行數:56,代碼來源:MigrationsDiffDoctrineCommand.class.php

示例12: assertCreatedSchemaNeedsNoUpdates

 public function assertCreatedSchemaNeedsNoUpdates($classes)
 {
     $classMetadata = array();
     foreach ($classes as $class) {
         $classMetadata[] = $this->_em->getClassMetadata($class);
     }
     $schemaTool = new Tools\SchemaTool($this->_em);
     $schemaTool->dropSchema($classMetadata);
     $schemaTool->createSchema($classMetadata);
     $sm = $this->_em->getConnection()->getSchemaManager();
     $fromSchema = $sm->createSchema();
     $toSchema = $schemaTool->getSchemaFromMetadata($classMetadata);
     $comparator = new \Doctrine\DBAL\Schema\Comparator();
     $schemaDiff = $comparator->compare($fromSchema, $toSchema);
     $sql = $schemaDiff->toSql($this->_em->getConnection()->getDatabasePlatform());
     $this->assertEquals(0, count($sql));
 }
開發者ID:jsuggs,項目名稱:BBM_old,代碼行數:17,代碼來源:DDC214Test.php

示例13: down

 /**
  * Down method.
  *
  * @param Schema $schema
  */
 public function down(Schema $schema)
 {
     if (Version::isSupportMethod()) {
         $app = Application::getInstance();
         $meta = $this->getMetadata($app['orm.em']);
         $tool = new SchemaTool($app['orm.em']);
         $schemaFromMetadata = $tool->getSchemaFromMetadata($meta);
         // テーブル削除
         foreach ($schemaFromMetadata->getTables() as $table) {
             if ($schema->hasTable($table->getName())) {
                 $schema->dropTable($table->getName());
             }
         }
     } else {
         if ($schema->hasTable(self::TABLE)) {
             $schema->dropTable(self::TABLE);
         }
     }
 }
開發者ID:EC-CUBE,項目名稱:order-pdf-plugin,代碼行數:24,代碼來源:Version201611111300.php

示例14: generateDatabaseVersionTable

 /**
  * Generates table for entity DatabaseVersion. Does not check if this table already exists.
  *
  * @throws \Doctrine\DBAL\DBALException
  * @throws \Doctrine\ORM\ORMException
  * @throws \Exception
  */
 private function generateDatabaseVersionTable()
 {
     $metadata = $this->entityManager->getMetadataFactory()->getAllMetadata();
     $tool = new SchemaTool($this->entityManager);
     $schema = $tool->getSchemaFromMetadata($metadata);
     $versionTable = null;
     foreach ($schema->getTables() as $table) {
         if ($table->getShortestName($schema->getName()) == self::VERSION_TABLE) {
             $versionTable = $table;
             break;
         }
     }
     if ($versionTable) {
         $platform = $this->entityManager->getConnection()->getDatabasePlatform();
         $sql = $platform->getCreateTableSQL($versionTable, AbstractPlatform::CREATE_INDEXES);
         $this->entityManager->getConnection()->executeQuery($sql[0]);
     } else {
         throw new \Exception('Error: Couldn\'t find database version entity definition.');
     }
 }
開發者ID:enhavo,項目名稱:enhavo,代碼行數:27,代碼來源:VersionAccessor.php

示例15: testForeignKeyOnSTIWithMultipleMapping

 /**
  * @group DDC-2138
  */
 public function testForeignKeyOnSTIWithMultipleMapping()
 {
     $em = $this->_em;
     $schemaTool = new SchemaTool($em);
     $classes = array($em->getClassMetadata(__NAMESPACE__ . '\\DDC2138User'), $em->getClassMetadata(__NAMESPACE__ . '\\DDC2138Structure'), $em->getClassMetadata(__NAMESPACE__ . '\\DDC2138UserFollowedObject'), $em->getClassMetadata(__NAMESPACE__ . '\\DDC2138UserFollowedStructure'), $em->getClassMetadata(__NAMESPACE__ . '\\DDC2138UserFollowedUser'));
     $schema = $schemaTool->getSchemaFromMetadata($classes);
     $this->assertTrue($schema->hasTable('users_followed_objects'), "Table users_followed_objects should exist.");
     /* @var $table \Doctrine\DBAL\Schema\Table */
     $table = $schema->getTable('users_followed_objects');
     $this->assertTrue($table->columnsAreIndexed(array('object_id')));
     $this->assertTrue($table->columnsAreIndexed(array('user_id')));
     $foreignKeys = $table->getForeignKeys();
     $this->assertCount(1, $foreignKeys, 'user_id column has to have FK, but not object_id');
     /* @var $fk \Doctrine\DBAL\Schema\ForeignKeyConstraint */
     $fk = reset($foreignKeys);
     $this->assertEquals('users', $fk->getForeignTableName());
     $localColumns = $fk->getLocalColumns();
     $this->assertContains('user_id', $localColumns);
     $this->assertCount(1, $localColumns);
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:23,代碼來源:DDC2138Test.php


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