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


PHP AbstractSchemaManager::listTableNames方法代碼示例

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


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

示例1: reverseEngineerMappingFromDatabase

 private function reverseEngineerMappingFromDatabase()
 {
     if ($this->tables !== null) {
         return;
     }
     foreach ($this->_sm->listTableNames() as $tableName) {
         $tables[strtolower($tableName)] = $this->_sm->listTableDetails($tableName);
     }
     $this->tables = array();
     foreach ($tables as $name => $table) {
         /* @var $table Table */
         if ($this->_sm->getDatabasePlatform()->supportsForeignKeyConstraints()) {
             $foreignKeys = $table->getForeignKeys();
         } else {
             $foreignKeys = array();
         }
         $allForeignKeyColumns = array();
         foreach ($foreignKeys as $foreignKey) {
             $allForeignKeyColumns = array_merge($allForeignKeyColumns, $foreignKey->getLocalColumns());
         }
         $pkColumns = $table->getPrimaryKey()->getColumns();
         sort($pkColumns);
         sort($allForeignKeyColumns);
         if ($pkColumns == $allForeignKeyColumns) {
             if (count($table->getForeignKeys()) > 2) {
                 throw new \InvalidArgumentException("ManyToMany table '" . $name . "' with more or less than two foreign keys are not supported by the Database Reverese Engineering Driver.");
             }
             $this->manyToManyTables[$name] = $table;
         } else {
             $className = Inflector::classify($name);
             $this->tables[$name] = $table;
             $this->classes[$className] = $name;
         }
     }
 }
開發者ID:skoop,項目名稱:symfony-sandbox,代碼行數:35,代碼來源:DatabaseDriver.php

示例2: reverseEngineerMappingFromDatabase

 private function reverseEngineerMappingFromDatabase()
 {
     if ($this->tables !== null) {
         return;
     }
     foreach ($this->_sm->listTableNames() as $tableName) {
         $tables[$tableName] = $this->_sm->listTableDetails($tableName);
     }
     $this->tables = $this->manyToManyTables = $this->classToTableNames = array();
     foreach ($tables as $tableName => $table) {
         /* @var $table Table */
         if ($this->_sm->getDatabasePlatform()->supportsForeignKeyConstraints()) {
             $foreignKeys = $table->getForeignKeys();
         } else {
             $foreignKeys = array();
         }
         $allForeignKeyColumns = array();
         foreach ($foreignKeys as $foreignKey) {
             $allForeignKeyColumns = array_merge($allForeignKeyColumns, $foreignKey->getLocalColumns());
         }
         $pkColumns = $table->getPrimaryKey()->getColumns();
         sort($pkColumns);
         sort($allForeignKeyColumns);
         if ($pkColumns == $allForeignKeyColumns && count($foreignKeys) == 2) {
             $this->manyToManyTables[$tableName] = $table;
         } else {
             // lower-casing is necessary because of Oracle Uppercase Tablenames,
             // assumption is lower-case + underscore separated.
             $className = Inflector::classify(strtolower($tableName));
             $this->tables[$tableName] = $table;
             $this->classToTableNames[$className] = $tableName;
         }
     }
 }
開發者ID:dracony,項目名稱:forked-php-orm-benchmark,代碼行數:34,代碼來源:DatabaseDriver.php

示例3: reverseEngineerMappingFromDatabase

 /**
  * @return void
  *
  * @throws \Doctrine\ORM\Mapping\MappingException
  */
 private function reverseEngineerMappingFromDatabase()
 {
     if ($this->tables !== null) {
         return;
     }
     $tables = array();
     foreach ($this->_sm->listTableNames() as $tableName) {
         $tables[$tableName] = $this->_sm->listTableDetails($tableName);
     }
     $this->tables = $this->manyToManyTables = $this->classToTableNames = array();
     foreach ($tables as $tableName => $table) {
         $foreignKeys = $this->_sm->getDatabasePlatform()->supportsForeignKeyConstraints() ? $table->getForeignKeys() : array();
         $allForeignKeyColumns = array();
         foreach ($foreignKeys as $foreignKey) {
             $allForeignKeyColumns = array_merge($allForeignKeyColumns, $foreignKey->getLocalColumns());
         }
         if (!$table->hasPrimaryKey()) {
             throw new MappingException("Table " . $table->getName() . " has no primary key. Doctrine does not " . "support reverse engineering from tables that don't have a primary key.");
         }
         $pkColumns = $table->getPrimaryKey()->getColumns();
         sort($pkColumns);
         sort($allForeignKeyColumns);
         if ($pkColumns == $allForeignKeyColumns && count($foreignKeys) == 2) {
             $this->manyToManyTables[$tableName] = $table;
         } else {
             // lower-casing is necessary because of Oracle Uppercase Tablenames,
             // assumption is lower-case + underscore separated.
             $className = $this->getClassNameForTable($tableName);
             $this->tables[$tableName] = $table;
             $this->classToTableNames[$className] = $tableName;
         }
     }
 }
開發者ID:rolas123,項目名稱:weather-homework,代碼行數:38,代碼來源:DatabaseDriver.php

示例4: getTables

 /**
  * @return mixed
  */
 public function getTables()
 {
     return $this->schema->listTableNames();
 }
開發者ID:xethron,項目名稱:migrations-generator,代碼行數:7,代碼來源:SchemaGenerator.php

示例5: tearDown

 public function tearDown()
 {
     foreach ($this->_sm->listTableNames() as $tableName) {
         $this->_sm->dropTable($tableName);
     }
 }
開發者ID:crate,項目名稱:crate-dbal,代碼行數:6,代碼來源:SchemaManagerTest.php


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