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


PHP AbstractSchemaManager::listTables方法代碼示例

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


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

示例1: _loadTables

 private function _loadTables()
 {
     if ($this->_tables === null) {
         $tables = $this->_sm->listTables();
         $this->_tables = array();
         foreach ($tables as $table) {
             $this->_tables[strtolower($table->getName())] = $table;
         }
     }
 }
開發者ID:matiasraies,項目名稱:Symfony2Inta,代碼行數:10,代碼來源:DoctrineMetadata.php

示例2: __construct

 public function __construct()
 {
     $this->schema = DB::getDoctrineSchemaManager();
     $this->schema->getDatabasePlatform()->registerDoctrineTypeMapping('enum', 'string');
     $this->tables = $this->schema->listTables();
     $this->relationships = [];
     //first create empty ruleset for each table
     foreach ($this->tables as $table) {
         $this->relationships[$table->getName()] = ['hasMany' => [], 'hasOne' => [], 'belongsTo' => [], 'belongsToMany' => []];
     }
     // get all relationships into $this->relationships variable
     $this->getAllRelationships();
 }
開發者ID:Goopil,項目名稱:laravel-generator,代碼行數:13,代碼來源:ModelRelationshipsGenerator.php

示例3: get_tables

 /**
  * Gets array \Doctrine\DBAL\Schema\Table
  *
  * @return array
  */
 public function get_tables()
 {
     /**
      * get tables
      */
     $tables = $this->sm->listTables();
     /**
      * unset ignore tables
      */
     $ignore_table_names = \Config::get('dbdocs.ignore_table_names', array());
     foreach ($ignore_table_names as $ignore_table_name) {
         foreach ($tables as $index => $table) {
             /* @var $table \Doctrine\DBAL\Schema\Table */
             if ($table->getName() == $ignore_table_name) {
                 unset($tables[$index]);
             }
         }
     }
     $ignore_table_name_regex = \Config::get('dbdocs.ignore_table_name_regex');
     if (!empty($ignore_table_name_regex)) {
         foreach ($tables as $index => $table) {
             /* @var $table \Doctrine\DBAL\Schema\Table */
             if (0 < preg_match($ignore_table_name_regex, $table->getName())) {
                 unset($tables[$index]);
             }
         }
     }
     return array_merge($tables, array());
 }
開發者ID:mp-php,項目名稱:fuel-packages-dbdocs,代碼行數:34,代碼來源:dbdocs.php

示例4: testListTables

 public function testListTables()
 {
     $this->createTestTable('list_tables_test');
     $tables = $this->_sm->listTables();
     $this->assertType('array', $tables);
     $this->assertTrue(count($tables) > 0);
     $foundTable = false;
     foreach ($tables as $table) {
         $this->assertType('Doctrine\\DBAL\\Schema\\Table', $table);
         if ($table->getName() == 'list_tables_test') {
             $foundTable = true;
             $this->assertTrue($table->hasColumn('id'));
             $this->assertTrue($table->hasColumn('test'));
             $this->assertTrue($table->hasColumn('foreign_key_test'));
         }
     }
 }
開發者ID:andreia,項目名稱:doctrine,代碼行數:17,代碼來源:SchemaManagerFunctionalTestCase.php

示例5: testListTables

 public function testListTables()
 {
     $this->createTestTable('list_tables_test');
     $tables = $this->_sm->listTables();
     $this->assertInternalType('array', $tables);
     $this->assertTrue(count($tables) > 0, "List Tables has to find at least one table named 'list_tables_test'.");
     $foundTable = false;
     foreach ($tables as $table) {
         $this->assertInstanceOf('Doctrine\\DBAL\\Schema\\Table', $table);
         if (strtolower($table->getName()) == 'list_tables_test') {
             $foundTable = true;
             $this->assertTrue($table->hasColumn('id'));
             $this->assertTrue($table->hasColumn('test'));
             $this->assertTrue($table->hasColumn('foreign_key_test'));
         }
     }
     $this->assertTrue($foundTable, "The 'list_tables_test' table has to be found.");
 }
開發者ID:llinder,項目名稱:FrameworkBenchmarks,代碼行數:18,代碼來源:SchemaManagerFunctionalTestCase.php

示例6: __construct

 public function __construct(\Doctrine\DBAL\Schema\AbstractSchemaManager $schema_manager)
 {
     $this->schema_manager = $schema_manager;
     foreach ($schema_manager->listTables() as $table) {
         $this->tables[$table->getName()] = new TableInformation($this, $table);
     }
     foreach ($this->tables as $table) {
         $this->findRelationships($table);
     }
 }
開發者ID:alanedwardes,項目名稱:carbo,代碼行數:10,代碼來源:SchemaInformation.php

示例7: saveSchemaToFile

 /**
  * @param $file
  * @param \Doctrine\DBAL\Schema\AbstractSchemaManager $sm
  * @return bool
  */
 public static function saveSchemaToFile($file, $sm)
 {
     $xml = new SimpleXMLElement('<database/>');
     $xml->addChild('name', OC_Config::getValue("dbname", "owncloud"));
     $xml->addChild('create', 'true');
     $xml->addChild('overwrite', 'false');
     $xml->addChild('charset', 'utf8');
     foreach ($sm->listTables() as $table) {
         self::saveTable($table, $xml->addChild('table'));
     }
     file_put_contents($file, $xml->asXML());
     return true;
 }
開發者ID:omusico,項目名稱:isle-web-framework,代碼行數:18,代碼來源:mdb2schemawriter.php

示例8: setRelations

 /**
  * @param EloquentModel $model
  * @return $this
  */
 protected function setRelations(EloquentModel $model)
 {
     $foreignKeys = $this->manager->listTableForeignKeys($this->addPrefix($model->getTableName()));
     foreach ($foreignKeys as $tableForeignKey) {
         $tableForeignColumns = $tableForeignKey->getForeignColumns();
         if (count($tableForeignColumns) !== 1) {
             continue;
         }
         $relation = new BelongsTo($this->cropPrefix($tableForeignKey->getForeignTableName()), $tableForeignKey->getLocalColumns()[0], $tableForeignColumns[0]);
         $model->addRelation($relation);
     }
     $tables = $this->manager->listTables();
     foreach ($tables as $table) {
         if ($table->getName() === $this->addPrefix($model->getTableName())) {
             continue;
         }
         $foreignKeys = $table->getForeignKeys();
         foreach ($foreignKeys as $name => $foreignKey) {
             if ($foreignKey->getForeignTableName() === $this->addPrefix($model->getTableName())) {
                 $localColumns = $foreignKey->getLocalColumns();
                 if (count($localColumns) !== 1) {
                     continue;
                 }
                 if (count($foreignKeys) === 2 && count($table->getColumns()) >= 2) {
                     $keys = array_keys($foreignKeys);
                     $key = array_search($name, $keys) === 0 ? 1 : 0;
                     $secondForeignKey = $foreignKeys[$keys[$key]];
                     $secondForeignTable = $secondForeignKey->getForeignTableName();
                     $relation = new BelongsToMany($this->cropPrefix($secondForeignTable), $table->getName(), $localColumns[0], $secondForeignKey->getLocalColumns()[0]);
                     $model->addRelation($relation);
                     break;
                 } else {
                     $tableName = $this->cropPrefix($foreignKey->getLocalTableName());
                     $foreignColumn = $localColumns[0];
                     $localColumn = $foreignKey->getForeignColumns()[0];
                     if ($this->isColumnUnique($table, $foreignColumn)) {
                         $relation = new HasOne($tableName, $foreignColumn, $localColumn);
                     } else {
                         $relation = new HasMany($tableName, $foreignColumn, $localColumn);
                     }
                     $model->addRelation($relation);
                 }
             }
         }
     }
     return $this;
 }
開發者ID:xvlady,項目名稱:eloquent-model-generator,代碼行數:51,代碼來源:EloquentModelBuilder.php


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