| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339 |
- <?php
- namespace Doctrine\DBAL\Schema;
- use Doctrine\DBAL\Connection;
- use Doctrine\DBAL\Event\SchemaColumnDefinitionEventArgs;
- use Doctrine\DBAL\Event\SchemaIndexDefinitionEventArgs;
- use Doctrine\DBAL\Events;
- use Doctrine\DBAL\Exception;
- use Doctrine\DBAL\Platforms\AbstractPlatform;
- use Doctrine\Deprecations\Deprecation;
- use Throwable;
- use function array_filter;
- use function array_intersect;
- use function array_map;
- use function array_values;
- use function assert;
- use function call_user_func_array;
- use function count;
- use function func_get_args;
- use function is_callable;
- use function is_string;
- use function preg_match;
- use function str_replace;
- use function strtolower;
- /**
- * Base class for schema managers. Schema managers are used to inspect and/or
- * modify the database schema/structure.
- *
- * @template T of AbstractPlatform
- */
- abstract class AbstractSchemaManager
- {
- /**
- * Holds instance of the Doctrine connection for this schema manager.
- *
- * @var Connection
- */
- protected $_conn;
- /**
- * Holds instance of the database platform used for this schema manager.
- *
- * @var T
- */
- protected $_platform;
- /**
- * @param T $platform
- */
- public function __construct(Connection $connection, AbstractPlatform $platform)
- {
- $this->_conn = $connection;
- $this->_platform = $platform;
- }
- /**
- * Returns the associated platform.
- *
- * @return T
- */
- public function getDatabasePlatform()
- {
- return $this->_platform;
- }
- /**
- * Tries any method on the schema manager. Normally a method throws an
- * exception when your DBMS doesn't support it or if an error occurs.
- * This method allows you to try and method on your SchemaManager
- * instance and will return false if it does not work or is not supported.
- *
- * <code>
- * $result = $sm->tryMethod('dropView', 'view_name');
- * </code>
- *
- * @deprecated
- *
- * @return mixed
- */
- public function tryMethod()
- {
- Deprecation::triggerIfCalledFromOutside(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::tryMethod() is deprecated.'
- );
- $args = func_get_args();
- $method = $args[0];
- unset($args[0]);
- $args = array_values($args);
- $callback = [$this, $method];
- assert(is_callable($callback));
- try {
- return call_user_func_array($callback, $args);
- } catch (Throwable $e) {
- return false;
- }
- }
- /**
- * Lists the available databases for this connection.
- *
- * @return string[]
- *
- * @throws Exception
- */
- public function listDatabases()
- {
- $sql = $this->_platform->getListDatabasesSQL();
- $databases = $this->_conn->fetchAllAssociative($sql);
- return $this->_getPortableDatabasesList($databases);
- }
- /**
- * Returns a list of all namespaces in the current database.
- *
- * @deprecated Use {@see listSchemaNames()} instead.
- *
- * @return string[]
- *
- * @throws Exception
- */
- public function listNamespaceNames()
- {
- Deprecation::triggerIfCalledFromOutside(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/issues/4503',
- 'AbstractSchemaManager::listNamespaceNames() is deprecated,'
- . ' use AbstractSchemaManager::listSchemaNames() instead.'
- );
- $sql = $this->_platform->getListNamespacesSQL();
- $namespaces = $this->_conn->fetchAllAssociative($sql);
- return $this->getPortableNamespacesList($namespaces);
- }
- /**
- * Returns a list of the names of all schemata in the current database.
- *
- * @return list<string>
- *
- * @throws Exception
- */
- public function listSchemaNames(): array
- {
- throw Exception::notSupported(__METHOD__);
- }
- /**
- * Lists the available sequences for this connection.
- *
- * @param string|null $database
- *
- * @return Sequence[]
- *
- * @throws Exception
- */
- public function listSequences($database = null)
- {
- if ($database === null) {
- $database = $this->_conn->getDatabase();
- }
- $sql = $this->_platform->getListSequencesSQL($database);
- $sequences = $this->_conn->fetchAllAssociative($sql);
- return $this->filterAssetNames($this->_getPortableSequencesList($sequences));
- }
- /**
- * Lists the columns for a given table.
- *
- * In contrast to other libraries and to the old version of Doctrine,
- * this column definition does try to contain the 'primary' column for
- * the reason that it is not portable across different RDBMS. Use
- * {@see listTableIndexes($tableName)} to retrieve the primary key
- * of a table. Where a RDBMS specifies more details, these are held
- * in the platformDetails array.
- *
- * @param string $table The name of the table.
- * @param string|null $database
- *
- * @return Column[]
- *
- * @throws Exception
- */
- public function listTableColumns($table, $database = null)
- {
- if ($database === null) {
- $database = $this->_conn->getDatabase();
- }
- $sql = $this->_platform->getListTableColumnsSQL($table, $database);
- $tableColumns = $this->_conn->fetchAllAssociative($sql);
- return $this->_getPortableTableColumnList($table, $database, $tableColumns);
- }
- /**
- * Lists the indexes for a given table returning an array of Index instances.
- *
- * Keys of the portable indexes list are all lower-cased.
- *
- * @param string $table The name of the table.
- *
- * @return Index[]
- *
- * @throws Exception
- */
- public function listTableIndexes($table)
- {
- $sql = $this->_platform->getListTableIndexesSQL($table, $this->_conn->getDatabase());
- $tableIndexes = $this->_conn->fetchAllAssociative($sql);
- return $this->_getPortableTableIndexesList($tableIndexes, $table);
- }
- /**
- * Returns true if all the given tables exist.
- *
- * The usage of a string $tableNames is deprecated. Pass a one-element array instead.
- *
- * @param string|string[] $names
- *
- * @return bool
- *
- * @throws Exception
- */
- public function tablesExist($names)
- {
- if (is_string($names)) {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/issues/3580',
- 'The usage of a string $tableNames in AbstractSchemaManager::tablesExist() is deprecated. ' .
- 'Pass a one-element array instead.'
- );
- }
- $names = array_map('strtolower', (array) $names);
- return count($names) === count(array_intersect($names, array_map('strtolower', $this->listTableNames())));
- }
- /**
- * Returns a list of all tables in the current database.
- *
- * @return string[]
- *
- * @throws Exception
- */
- public function listTableNames()
- {
- $sql = $this->_platform->getListTablesSQL();
- $tables = $this->_conn->fetchAllAssociative($sql);
- $tableNames = $this->_getPortableTablesList($tables);
- return $this->filterAssetNames($tableNames);
- }
- /**
- * Filters asset names if they are configured to return only a subset of all
- * the found elements.
- *
- * @param mixed[] $assetNames
- *
- * @return mixed[]
- */
- protected function filterAssetNames($assetNames)
- {
- $filter = $this->_conn->getConfiguration()->getSchemaAssetsFilter();
- if ($filter === null) {
- return $assetNames;
- }
- return array_values(array_filter($assetNames, $filter));
- }
- /**
- * Lists the tables for this connection.
- *
- * @return Table[]
- *
- * @throws Exception
- */
- public function listTables()
- {
- $tableNames = $this->listTableNames();
- $tables = [];
- foreach ($tableNames as $tableName) {
- $tables[] = $this->listTableDetails($tableName);
- }
- return $tables;
- }
- /**
- * @param string $name
- *
- * @return Table
- *
- * @throws Exception
- */
- public function listTableDetails($name)
- {
- $columns = $this->listTableColumns($name);
- $foreignKeys = [];
- if ($this->_platform->supportsForeignKeyConstraints()) {
- $foreignKeys = $this->listTableForeignKeys($name);
- }
- $indexes = $this->listTableIndexes($name);
- return new Table($name, $columns, $indexes, [], $foreignKeys);
- }
- /**
- * Lists the views this connection has.
- *
- * @return View[]
- *
- * @throws Exception
- */
- public function listViews()
- {
- $database = $this->_conn->getDatabase();
- $sql = $this->_platform->getListViewsSQL($database);
- $views = $this->_conn->fetchAllAssociative($sql);
- return $this->_getPortableViewsList($views);
- }
- /**
- * Lists the foreign keys for the given table.
- *
- * @param string $table The name of the table.
- * @param string|null $database
- *
- * @return ForeignKeyConstraint[]
- *
- * @throws Exception
- */
- public function listTableForeignKeys($table, $database = null)
- {
- if ($database === null) {
- $database = $this->_conn->getDatabase();
- }
- $sql = $this->_platform->getListTableForeignKeysSQL($table, $database);
- $tableForeignKeys = $this->_conn->fetchAllAssociative($sql);
- return $this->_getPortableTableForeignKeysList($tableForeignKeys);
- }
- /* drop*() Methods */
- /**
- * Drops a database.
- *
- * NOTE: You can not drop the database this SchemaManager is currently connected to.
- *
- * @param string $database The name of the database to drop.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropDatabase($database)
- {
- $this->_execSql($this->_platform->getDropDatabaseSQL($database));
- }
- /**
- * Drops a schema.
- *
- * @throws Exception
- */
- public function dropSchema(string $schemaName): void
- {
- $this->_execSql($this->_platform->getDropSchemaSQL($schemaName));
- }
- /**
- * Drops the given table.
- *
- * @param string $name The name of the table to drop.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropTable($name)
- {
- $this->_execSql($this->_platform->getDropTableSQL($name));
- }
- /**
- * Drops the index from the given table.
- *
- * @param Index|string $index The name of the index.
- * @param Table|string $table The name of the table.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropIndex($index, $table)
- {
- if ($index instanceof Index) {
- $index = $index->getQuotedName($this->_platform);
- }
- $this->_execSql($this->_platform->getDropIndexSQL($index, $table));
- }
- /**
- * Drops the constraint from the given table.
- *
- * @deprecated Use {@see dropIndex()}, {@see dropForeignKey()} or {@see dropUniqueConstraint()} instead.
- *
- * @param Table|string $table The name of the table.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropConstraint(Constraint $constraint, $table)
- {
- $this->_execSql($this->_platform->getDropConstraintSQL($constraint, $table));
- }
- /**
- * Drops a foreign key from a table.
- *
- * @param ForeignKeyConstraint|string $foreignKey The name of the foreign key.
- * @param Table|string $table The name of the table with the foreign key.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropForeignKey($foreignKey, $table)
- {
- $this->_execSql($this->_platform->getDropForeignKeySQL($foreignKey, $table));
- }
- /**
- * Drops a sequence with a given name.
- *
- * @param string $name The name of the sequence to drop.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropSequence($name)
- {
- $this->_execSql($this->_platform->getDropSequenceSQL($name));
- }
- /**
- * Drops the unique constraint from the given table.
- *
- * @throws Exception
- */
- public function dropUniqueConstraint(string $name, string $tableName): void
- {
- $this->_execSql($this->_platform->getDropUniqueConstraintSQL($name, $tableName));
- }
- /**
- * Drops a view.
- *
- * @param string $name The name of the view.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropView($name)
- {
- $this->_execSql($this->_platform->getDropViewSQL($name));
- }
- /* create*() Methods */
- /**
- * Creates a new database.
- *
- * @param string $database The name of the database to create.
- *
- * @return void
- *
- * @throws Exception
- */
- public function createDatabase($database)
- {
- $this->_execSql($this->_platform->getCreateDatabaseSQL($database));
- }
- /**
- * Creates a new table.
- *
- * @return void
- *
- * @throws Exception
- */
- public function createTable(Table $table)
- {
- $createFlags = AbstractPlatform::CREATE_INDEXES | AbstractPlatform::CREATE_FOREIGNKEYS;
- $this->_execSql($this->_platform->getCreateTableSQL($table, $createFlags));
- }
- /**
- * Creates a new sequence.
- *
- * @param Sequence $sequence
- *
- * @return void
- *
- * @throws Exception
- */
- public function createSequence($sequence)
- {
- $this->_execSql($this->_platform->getCreateSequenceSQL($sequence));
- }
- /**
- * Creates a constraint on a table.
- *
- * @deprecated Use {@see createIndex()}, {@see createForeignKey()} or {@see createUniqueConstraint()} instead.
- *
- * @param Table|string $table
- *
- * @return void
- *
- * @throws Exception
- */
- public function createConstraint(Constraint $constraint, $table)
- {
- $this->_execSql($this->_platform->getCreateConstraintSQL($constraint, $table));
- }
- /**
- * Creates a new index on a table.
- *
- * @param Table|string $table The name of the table on which the index is to be created.
- *
- * @return void
- *
- * @throws Exception
- */
- public function createIndex(Index $index, $table)
- {
- $this->_execSql($this->_platform->getCreateIndexSQL($index, $table));
- }
- /**
- * Creates a new foreign key.
- *
- * @param ForeignKeyConstraint $foreignKey The ForeignKey instance.
- * @param Table|string $table The name of the table on which the foreign key is to be created.
- *
- * @return void
- *
- * @throws Exception
- */
- public function createForeignKey(ForeignKeyConstraint $foreignKey, $table)
- {
- $this->_execSql($this->_platform->getCreateForeignKeySQL($foreignKey, $table));
- }
- /**
- * Creates a unique constraint on a table.
- *
- * @throws Exception
- */
- public function createUniqueConstraint(UniqueConstraint $uniqueConstraint, string $tableName): void
- {
- $this->_execSql($this->_platform->getCreateUniqueConstraintSQL($uniqueConstraint, $tableName));
- }
- /**
- * Creates a new view.
- *
- * @return void
- *
- * @throws Exception
- */
- public function createView(View $view)
- {
- $this->_execSql($this->_platform->getCreateViewSQL($view->getQuotedName($this->_platform), $view->getSql()));
- }
- /* dropAndCreate*() Methods */
- /**
- * Drops and creates a constraint.
- *
- * @deprecated Use {@see dropIndex()} and {@see createIndex()},
- * {@see dropForeignKey()} and {@see createForeignKey()}
- * or {@see dropUniqueConstraint()} and {@see createUniqueConstraint()} instead.
- *
- * @see dropConstraint()
- * @see createConstraint()
- *
- * @param Table|string $table
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateConstraint(Constraint $constraint, $table)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateConstraint() is deprecated.'
- . ' Use AbstractSchemaManager::dropIndex() and AbstractSchemaManager::createIndex(),'
- . ' AbstractSchemaManager::dropForeignKey() and AbstractSchemaManager::createForeignKey()'
- . ' or AbstractSchemaManager::dropUniqueConstraint()'
- . ' and AbstractSchemaManager::createUniqueConstraint() instead.'
- );
- $this->tryMethod('dropConstraint', $constraint, $table);
- $this->createConstraint($constraint, $table);
- }
- /**
- * Drops and creates a new index on a table.
- *
- * @deprecated Use {@see dropIndex()} and {@see createIndex()} instead.
- *
- * @param Table|string $table The name of the table on which the index is to be created.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateIndex(Index $index, $table)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateIndex() is deprecated.'
- . ' Use AbstractSchemaManager::dropIndex() and AbstractSchemaManager::createIndex() instead.'
- );
- $this->tryMethod('dropIndex', $index->getQuotedName($this->_platform), $table);
- $this->createIndex($index, $table);
- }
- /**
- * Drops and creates a new foreign key.
- *
- * @deprecated Use {@see dropForeignKey()} and {@see createForeignKey()} instead.
- *
- * @param ForeignKeyConstraint $foreignKey An associative array that defines properties
- * of the foreign key to be created.
- * @param Table|string $table The name of the table on which the foreign key is to be created.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateForeignKey(ForeignKeyConstraint $foreignKey, $table)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateForeignKey() is deprecated.'
- . ' Use AbstractSchemaManager::dropForeignKey() and AbstractSchemaManager::createForeignKey() instead.'
- );
- $this->tryMethod('dropForeignKey', $foreignKey, $table);
- $this->createForeignKey($foreignKey, $table);
- }
- /**
- * Drops and create a new sequence.
- *
- * @deprecated Use {@see dropSequence()} and {@see createSequence()} instead.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateSequence(Sequence $sequence)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateSequence() is deprecated.'
- . ' Use AbstractSchemaManager::dropSequence() and AbstractSchemaManager::createSequence() instead.'
- );
- $this->tryMethod('dropSequence', $sequence->getQuotedName($this->_platform));
- $this->createSequence($sequence);
- }
- /**
- * Drops and creates a new table.
- *
- * @deprecated Use {@see dropTable()} and {@see createTable()} instead.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateTable(Table $table)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateTable() is deprecated.'
- . ' Use AbstractSchemaManager::dropTable() and AbstractSchemaManager::createTable() instead.'
- );
- $this->tryMethod('dropTable', $table->getQuotedName($this->_platform));
- $this->createTable($table);
- }
- /**
- * Drops and creates a new database.
- *
- * @deprecated Use {@see dropDatabase()} and {@see createDatabase()} instead.
- *
- * @param string $database The name of the database to create.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateDatabase($database)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateDatabase() is deprecated.'
- . ' Use AbstractSchemaManager::dropDatabase() and AbstractSchemaManager::createDatabase() instead.'
- );
- $this->tryMethod('dropDatabase', $database);
- $this->createDatabase($database);
- }
- /**
- * Drops and creates a new view.
- *
- * @deprecated Use {@see dropView()} and {@see createView()} instead.
- *
- * @return void
- *
- * @throws Exception
- */
- public function dropAndCreateView(View $view)
- {
- Deprecation::trigger(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4897',
- 'AbstractSchemaManager::dropAndCreateView() is deprecated.'
- . ' Use AbstractSchemaManager::dropView() and AbstractSchemaManager::createView() instead.'
- );
- $this->tryMethod('dropView', $view->getQuotedName($this->_platform));
- $this->createView($view);
- }
- /**
- * Alters an existing schema.
- *
- * @throws Exception
- */
- public function alterSchema(SchemaDiff $schemaDiff): void
- {
- $this->_execSql($schemaDiff->toSql($this->_platform));
- }
- /**
- * Migrates an existing schema to a new schema.
- *
- * @throws Exception
- */
- public function migrateSchema(Schema $toSchema): void
- {
- $schemaDiff = $this->createComparator()
- ->compareSchemas($this->createSchema(), $toSchema);
- $this->alterSchema($schemaDiff);
- }
- /* alterTable() Methods */
- /**
- * Alters an existing tables schema.
- *
- * @return void
- *
- * @throws Exception
- */
- public function alterTable(TableDiff $tableDiff)
- {
- foreach ($this->_platform->getAlterTableSQL($tableDiff) as $ddlQuery) {
- $this->_execSql($ddlQuery);
- }
- }
- /**
- * Renames a given table to another name.
- *
- * @param string $name The current name of the table.
- * @param string $newName The new name of the table.
- *
- * @return void
- *
- * @throws Exception
- */
- public function renameTable($name, $newName)
- {
- $tableDiff = new TableDiff($name);
- $tableDiff->newName = $newName;
- $this->alterTable($tableDiff);
- }
- /**
- * Methods for filtering return values of list*() methods to convert
- * the native DBMS data definition to a portable Doctrine definition
- */
- /**
- * @param mixed[] $databases
- *
- * @return string[]
- */
- protected function _getPortableDatabasesList($databases)
- {
- $list = [];
- foreach ($databases as $value) {
- $list[] = $this->_getPortableDatabaseDefinition($value);
- }
- return $list;
- }
- /**
- * Converts a list of namespace names from the native DBMS data definition to a portable Doctrine definition.
- *
- * @deprecated Use {@see listSchemaNames()} instead.
- *
- * @param array<int, array<string, mixed>> $namespaces The list of namespace names
- * in the native DBMS data definition.
- *
- * @return string[]
- */
- protected function getPortableNamespacesList(array $namespaces)
- {
- Deprecation::triggerIfCalledFromOutside(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/issues/4503',
- 'AbstractSchemaManager::getPortableNamespacesList() is deprecated,'
- . ' use AbstractSchemaManager::listSchemaNames() instead.'
- );
- $namespacesList = [];
- foreach ($namespaces as $namespace) {
- $namespacesList[] = $this->getPortableNamespaceDefinition($namespace);
- }
- return $namespacesList;
- }
- /**
- * @param mixed $database
- *
- * @return mixed
- */
- protected function _getPortableDatabaseDefinition($database)
- {
- return $database;
- }
- /**
- * Converts a namespace definition from the native DBMS data definition to a portable Doctrine definition.
- *
- * @deprecated Use {@see listSchemaNames()} instead.
- *
- * @param array<string, mixed> $namespace The native DBMS namespace definition.
- *
- * @return mixed
- */
- protected function getPortableNamespaceDefinition(array $namespace)
- {
- Deprecation::triggerIfCalledFromOutside(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/issues/4503',
- 'AbstractSchemaManager::getPortableNamespaceDefinition() is deprecated,'
- . ' use AbstractSchemaManager::listSchemaNames() instead.'
- );
- return $namespace;
- }
- /**
- * @param mixed[][] $sequences
- *
- * @return Sequence[]
- *
- * @throws Exception
- */
- protected function _getPortableSequencesList($sequences)
- {
- $list = [];
- foreach ($sequences as $value) {
- $list[] = $this->_getPortableSequenceDefinition($value);
- }
- return $list;
- }
- /**
- * @param mixed[] $sequence
- *
- * @return Sequence
- *
- * @throws Exception
- */
- protected function _getPortableSequenceDefinition($sequence)
- {
- throw Exception::notSupported('Sequences');
- }
- /**
- * Independent of the database the keys of the column list result are lowercased.
- *
- * The name of the created column instance however is kept in its case.
- *
- * @param string $table The name of the table.
- * @param string $database
- * @param mixed[][] $tableColumns
- *
- * @return Column[]
- *
- * @throws Exception
- */
- protected function _getPortableTableColumnList($table, $database, $tableColumns)
- {
- $eventManager = $this->_platform->getEventManager();
- $list = [];
- foreach ($tableColumns as $tableColumn) {
- $column = null;
- $defaultPrevented = false;
- if ($eventManager !== null && $eventManager->hasListeners(Events::onSchemaColumnDefinition)) {
- $eventArgs = new SchemaColumnDefinitionEventArgs($tableColumn, $table, $database, $this->_conn);
- $eventManager->dispatchEvent(Events::onSchemaColumnDefinition, $eventArgs);
- $defaultPrevented = $eventArgs->isDefaultPrevented();
- $column = $eventArgs->getColumn();
- }
- if (! $defaultPrevented) {
- $column = $this->_getPortableTableColumnDefinition($tableColumn);
- }
- if ($column === null) {
- continue;
- }
- $name = strtolower($column->getQuotedName($this->_platform));
- $list[$name] = $column;
- }
- return $list;
- }
- /**
- * Gets Table Column Definition.
- *
- * @param mixed[] $tableColumn
- *
- * @return Column
- *
- * @throws Exception
- */
- abstract protected function _getPortableTableColumnDefinition($tableColumn);
- /**
- * Aggregates and groups the index results according to the required data result.
- *
- * @param mixed[][] $tableIndexes
- * @param string|null $tableName
- *
- * @return Index[]
- *
- * @throws Exception
- */
- protected function _getPortableTableIndexesList($tableIndexes, $tableName = null)
- {
- $result = [];
- foreach ($tableIndexes as $tableIndex) {
- $indexName = $keyName = $tableIndex['key_name'];
- if ($tableIndex['primary']) {
- $keyName = 'primary';
- }
- $keyName = strtolower($keyName);
- if (! isset($result[$keyName])) {
- $options = [
- 'lengths' => [],
- ];
- if (isset($tableIndex['where'])) {
- $options['where'] = $tableIndex['where'];
- }
- $result[$keyName] = [
- 'name' => $indexName,
- 'columns' => [],
- 'unique' => ! $tableIndex['non_unique'],
- 'primary' => $tableIndex['primary'],
- 'flags' => $tableIndex['flags'] ?? [],
- 'options' => $options,
- ];
- }
- $result[$keyName]['columns'][] = $tableIndex['column_name'];
- $result[$keyName]['options']['lengths'][] = $tableIndex['length'] ?? null;
- }
- $eventManager = $this->_platform->getEventManager();
- $indexes = [];
- foreach ($result as $indexKey => $data) {
- $index = null;
- $defaultPrevented = false;
- if ($eventManager !== null && $eventManager->hasListeners(Events::onSchemaIndexDefinition)) {
- $eventArgs = new SchemaIndexDefinitionEventArgs($data, $tableName, $this->_conn);
- $eventManager->dispatchEvent(Events::onSchemaIndexDefinition, $eventArgs);
- $defaultPrevented = $eventArgs->isDefaultPrevented();
- $index = $eventArgs->getIndex();
- }
- if (! $defaultPrevented) {
- $index = new Index(
- $data['name'],
- $data['columns'],
- $data['unique'],
- $data['primary'],
- $data['flags'],
- $data['options']
- );
- }
- if ($index === null) {
- continue;
- }
- $indexes[$indexKey] = $index;
- }
- return $indexes;
- }
- /**
- * @param mixed[][] $tables
- *
- * @return string[]
- */
- protected function _getPortableTablesList($tables)
- {
- $list = [];
- foreach ($tables as $value) {
- $list[] = $this->_getPortableTableDefinition($value);
- }
- return $list;
- }
- /**
- * @param mixed $table
- *
- * @return string
- */
- protected function _getPortableTableDefinition($table)
- {
- return $table;
- }
- /**
- * @param mixed[][] $users
- *
- * @return string[][]
- */
- protected function _getPortableUsersList($users)
- {
- $list = [];
- foreach ($users as $value) {
- $list[] = $this->_getPortableUserDefinition($value);
- }
- return $list;
- }
- /**
- * @param string[] $user
- *
- * @return string[]
- */
- protected function _getPortableUserDefinition($user)
- {
- return $user;
- }
- /**
- * @param mixed[][] $views
- *
- * @return View[]
- */
- protected function _getPortableViewsList($views)
- {
- $list = [];
- foreach ($views as $value) {
- $view = $this->_getPortableViewDefinition($value);
- if ($view === false) {
- continue;
- }
- $viewName = strtolower($view->getQuotedName($this->_platform));
- $list[$viewName] = $view;
- }
- return $list;
- }
- /**
- * @param mixed[] $view
- *
- * @return View|false
- */
- protected function _getPortableViewDefinition($view)
- {
- return false;
- }
- /**
- * @param mixed[][] $tableForeignKeys
- *
- * @return ForeignKeyConstraint[]
- */
- protected function _getPortableTableForeignKeysList($tableForeignKeys)
- {
- $list = [];
- foreach ($tableForeignKeys as $value) {
- $list[] = $this->_getPortableTableForeignKeyDefinition($value);
- }
- return $list;
- }
- /**
- * @param mixed $tableForeignKey
- *
- * @return ForeignKeyConstraint
- */
- protected function _getPortableTableForeignKeyDefinition($tableForeignKey)
- {
- return $tableForeignKey;
- }
- /**
- * @param string[]|string $sql
- *
- * @return void
- *
- * @throws Exception
- */
- protected function _execSql($sql)
- {
- foreach ((array) $sql as $query) {
- $this->_conn->executeStatement($query);
- }
- }
- /**
- * Creates a schema instance for the current database.
- *
- * @return Schema
- *
- * @throws Exception
- */
- public function createSchema()
- {
- $schemaNames = [];
- if ($this->_platform->supportsSchemas()) {
- $schemaNames = $this->listNamespaceNames();
- }
- $sequences = [];
- if ($this->_platform->supportsSequences()) {
- $sequences = $this->listSequences();
- }
- $tables = $this->listTables();
- return new Schema($tables, $sequences, $this->createSchemaConfig(), $schemaNames);
- }
- /**
- * Creates the configuration for this schema.
- *
- * @return SchemaConfig
- *
- * @throws Exception
- */
- public function createSchemaConfig()
- {
- $schemaConfig = new SchemaConfig();
- $schemaConfig->setMaxIdentifierLength($this->_platform->getMaxIdentifierLength());
- $searchPaths = $this->getSchemaSearchPaths();
- if (isset($searchPaths[0])) {
- $schemaConfig->setName($searchPaths[0]);
- }
- $params = $this->_conn->getParams();
- if (! isset($params['defaultTableOptions'])) {
- $params['defaultTableOptions'] = [];
- }
- if (! isset($params['defaultTableOptions']['charset']) && isset($params['charset'])) {
- $params['defaultTableOptions']['charset'] = $params['charset'];
- }
- $schemaConfig->setDefaultTableOptions($params['defaultTableOptions']);
- return $schemaConfig;
- }
- /**
- * The search path for namespaces in the currently connected database.
- *
- * The first entry is usually the default namespace in the Schema. All
- * further namespaces contain tables/sequences which can also be addressed
- * with a short, not full-qualified name.
- *
- * For databases that don't support subschema/namespaces this method
- * returns the name of the currently connected database.
- *
- * @deprecated
- *
- * @return string[]
- *
- * @throws Exception
- */
- public function getSchemaSearchPaths()
- {
- Deprecation::triggerIfCalledFromOutside(
- 'doctrine/dbal',
- 'https://github.com/doctrine/dbal/pull/4821',
- 'AbstractSchemaManager::getSchemaSearchPaths() is deprecated.'
- );
- $database = $this->_conn->getDatabase();
- if ($database !== null) {
- return [$database];
- }
- return [];
- }
- /**
- * Given a table comment this method tries to extract a typehint for Doctrine Type, or returns
- * the type given as default.
- *
- * @internal This method should be only used from within the AbstractSchemaManager class hierarchy.
- *
- * @param string|null $comment
- * @param string $currentType
- *
- * @return string
- */
- public function extractDoctrineTypeFromComment($comment, $currentType)
- {
- if ($comment !== null && preg_match('(\(DC2Type:(((?!\)).)+)\))', $comment, $match) === 1) {
- return $match[1];
- }
- return $currentType;
- }
- /**
- * @internal This method should be only used from within the AbstractSchemaManager class hierarchy.
- *
- * @param string|null $comment
- * @param string|null $type
- *
- * @return string|null
- */
- public function removeDoctrineTypeFromComment($comment, $type)
- {
- if ($comment === null) {
- return null;
- }
- return str_replace('(DC2Type:' . $type . ')', '', $comment);
- }
- public function createComparator(): Comparator
- {
- return new Comparator($this->getDatabasePlatform());
- }
- }
|