From 042de0de2844c8ef8848310637bae2e47461e7d6 Mon Sep 17 00:00:00 2001 From: Sergei Morozov Date: Mon, 27 May 2019 16:19:20 -0700 Subject: [PATCH] Enforced parameter and return value types in Platform classes --- .../DBAL/Driver/AbstractSQLiteDriver.php | 2 +- .../DBAL/Platforms/AbstractPlatform.php | 696 +++++------------- lib/Doctrine/DBAL/Platforms/DB2Platform.php | 107 ++- .../DBAL/Platforms/Keywords/DB2Keywords.php | 4 +- .../DBAL/Platforms/Keywords/KeywordList.php | 17 +- .../Platforms/Keywords/MySQL57Keywords.php | 4 +- .../Platforms/Keywords/MySQL80Keywords.php | 4 +- .../DBAL/Platforms/Keywords/MySQLKeywords.php | 4 +- .../Platforms/Keywords/OracleKeywords.php | 4 +- .../Keywords/PostgreSQL94Keywords.php | 4 +- .../Platforms/Keywords/PostgreSQLKeywords.php | 4 +- .../Keywords/ReservedKeywordsValidator.php | 23 +- .../Keywords/SQLAnywhereKeywords.php | 4 +- .../Keywords/SQLServer2012Keywords.php | 4 +- .../Platforms/Keywords/SQLServerKeywords.php | 4 +- .../Platforms/Keywords/SQLiteKeywords.php | 4 +- .../DBAL/Platforms/MySQL57Platform.php | 14 +- .../DBAL/Platforms/MySQL80Platform.php | 2 +- lib/Doctrine/DBAL/Platforms/MySqlPlatform.php | 177 +++-- .../DBAL/Platforms/OraclePlatform.php | 147 ++-- .../DBAL/Platforms/PostgreSQL100Platform.php | 2 +- .../DBAL/Platforms/PostgreSQL94Platform.php | 8 +- .../DBAL/Platforms/PostgreSqlPlatform.php | 190 +++-- .../DBAL/Platforms/SQLAnywherePlatform.php | 200 +++-- .../DBAL/Platforms/SQLAzurePlatform.php | 2 +- .../DBAL/Platforms/SQLServer2012Platform.php | 14 +- .../DBAL/Platforms/SQLServerPlatform.php | 258 +++---- .../DBAL/Platforms/SqlitePlatform.php | 183 +++-- .../Driver/PDOSqlite/DriverTest.php | 8 + .../SchemaManagerFunctionalTestCase.php | 26 +- .../Platforms/AbstractPlatformTestCase.php | 4 +- .../AbstractSQLServerPlatformTestCase.php | 6 +- .../Platforms/SQLAnywherePlatformTest.php | 13 - .../DBAL/Platforms/SQLServerPlatformTest.php | 2 - .../DBAL/Platforms/SqlitePlatformTest.php | 2 +- 35 files changed, 849 insertions(+), 1298 deletions(-) diff --git a/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php b/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php index 05fe3b62051..760e9a0ca33 100644 --- a/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php +++ b/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php @@ -83,7 +83,7 @@ public function getDatabase(Connection $conn) : ?string { $params = $conn->getParams(); - return $params['path'] ?? null; + return $params['path'] ?? ''; } /** diff --git a/lib/Doctrine/DBAL/Platforms/AbstractPlatform.php b/lib/Doctrine/DBAL/Platforms/AbstractPlatform.php index 3b71b68143e..1a0223ad33d 100644 --- a/lib/Doctrine/DBAL/Platforms/AbstractPlatform.php +++ b/lib/Doctrine/DBAL/Platforms/AbstractPlatform.php @@ -46,6 +46,7 @@ use function in_array; use function is_array; use function is_bool; +use function is_float; use function is_int; use function is_string; use function preg_quote; @@ -81,7 +82,7 @@ abstract class AbstractPlatform */ protected $doctrineTypeComments = null; - /** @var EventManager */ + /** @var EventManager|null */ protected $_eventManager; /** @@ -98,17 +99,15 @@ public function __construct() /** * Sets the EventManager used by the Platform. */ - public function setEventManager(EventManager $eventManager) + public function setEventManager(EventManager $eventManager) : void { $this->_eventManager = $eventManager; } /** * Gets the EventManager used by the Platform. - * - * @return EventManager */ - public function getEventManager() + public function getEventManager() : ?EventManager { return $this->_eventManager; } @@ -117,61 +116,47 @@ public function getEventManager() * Returns the SQL snippet that declares a boolean column. * * @param mixed[] $columnDef - * - * @return string */ - abstract public function getBooleanTypeDeclarationSQL(array $columnDef); + abstract public function getBooleanTypeDeclarationSQL(array $columnDef) : string; /** * Returns the SQL snippet that declares a 4 byte integer column. * * @param mixed[] $columnDef - * - * @return string */ - abstract public function getIntegerTypeDeclarationSQL(array $columnDef); + abstract public function getIntegerTypeDeclarationSQL(array $columnDef) : string; /** * Returns the SQL snippet that declares an 8 byte integer column. * * @param mixed[] $columnDef - * - * @return string */ - abstract public function getBigIntTypeDeclarationSQL(array $columnDef); + abstract public function getBigIntTypeDeclarationSQL(array $columnDef) : string; /** * Returns the SQL snippet that declares a 2 byte integer column. * * @param mixed[] $columnDef - * - * @return string */ - abstract public function getSmallIntTypeDeclarationSQL(array $columnDef); + abstract public function getSmallIntTypeDeclarationSQL(array $columnDef) : string; /** * Returns the SQL snippet that declares common properties of an integer column. * * @param mixed[] $columnDef - * - * @return string */ - abstract protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef); + abstract protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string; /** * Lazy load Doctrine Type Mappings. - * - * @return void */ - abstract protected function initializeDoctrineTypeMappings(); + abstract protected function initializeDoctrineTypeMappings() : void; /** * Initializes Doctrine Type Mappings with the platform defaults * and with all additional type mappings. - * - * @return void */ - private function initializeAllDoctrineTypeMappings() + private function initializeAllDoctrineTypeMappings() : void { $this->initializeDoctrineTypeMappings(); @@ -186,10 +171,8 @@ private function initializeAllDoctrineTypeMappings() * Returns the SQL snippet used to declare a VARCHAR column type. * * @param mixed[] $field - * - * @return string */ - public function getVarcharTypeDeclarationSQL(array $field) + public function getVarcharTypeDeclarationSQL(array $field) : string { if (! isset($field['length'])) { $field['length'] = $this->getVarcharDefaultLength(); @@ -212,10 +195,8 @@ public function getVarcharTypeDeclarationSQL(array $field) * Returns the SQL snippet used to declare a BINARY/VARBINARY column type. * * @param mixed[] $field The column definition. - * - * @return string */ - public function getBinaryTypeDeclarationSQL(array $field) + public function getBinaryTypeDeclarationSQL(array $field) : string { if (! isset($field['length'])) { $field['length'] = $this->getBinaryDefaultLength(); @@ -233,10 +214,8 @@ public function getBinaryTypeDeclarationSQL(array $field) * special datatypes when the underlying databases support this datatype. * * @param mixed[] $field - * - * @return string */ - public function getGuidTypeDeclarationSQL(array $field) + public function getGuidTypeDeclarationSQL(array $field) : string { $field['length'] = 36; $field['fixed'] = true; @@ -251,23 +230,19 @@ public function getGuidTypeDeclarationSQL(array $field) * special datatypes when the underlying databases support this datatype. * * @param mixed[] $field - * - * @return string */ - public function getJsonTypeDeclarationSQL(array $field) + public function getJsonTypeDeclarationSQL(array $field) : string { return $this->getClobTypeDeclarationSQL($field); } /** - * @param int $length - * @param bool $fixed - * - * @return string + * @param int $length The length of the column. + * @param bool $fixed Whether the column length is fixed. * * @throws DBALException If not supported on this platform. */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { throw NotSupported::new('VARCHARs not supported by Platform.'); } @@ -278,11 +253,9 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) * @param int $length The length of the column. * @param bool $fixed Whether the column length is fixed. * - * @return string - * * @throws DBALException If not supported on this platform. */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { throw NotSupported::new('BINARY/VARBINARY column types are not supported by this platform.'); } @@ -291,36 +264,27 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) * Returns the SQL snippet used to declare a CLOB column type. * * @param mixed[] $field - * - * @return string */ - abstract public function getClobTypeDeclarationSQL(array $field); + abstract public function getClobTypeDeclarationSQL(array $field) : string; /** * Returns the SQL Snippet used to declare a BLOB column type. * * @param mixed[] $field - * - * @return string */ - abstract public function getBlobTypeDeclarationSQL(array $field); + abstract public function getBlobTypeDeclarationSQL(array $field) : string; /** * Gets the name of the platform. - * - * @return string */ - abstract public function getName(); + abstract public function getName() : string; /** * Registers a doctrine type to be used in conjunction with a column type of this platform. * - * @param string $dbType - * @param string $doctrineType - * * @throws DBALException If the type is not found. */ - public function registerDoctrineTypeMapping($dbType, $doctrineType) + public function registerDoctrineTypeMapping(string $dbType, string $doctrineType) : void { if ($this->doctrineTypeMapping === null) { $this->initializeAllDoctrineTypeMappings(); @@ -345,13 +309,9 @@ public function registerDoctrineTypeMapping($dbType, $doctrineType) /** * Gets the Doctrine type that is mapped for the given database column type. * - * @param string $dbType - * - * @return string - * * @throws DBALException */ - public function getDoctrineTypeMapping($dbType) + public function getDoctrineTypeMapping(string $dbType) : string { if ($this->doctrineTypeMapping === null) { $this->initializeAllDoctrineTypeMappings(); @@ -372,12 +332,8 @@ public function getDoctrineTypeMapping($dbType) /** * Checks if a database type is currently supported by this platform. - * - * @param string $dbType - * - * @return bool */ - public function hasDoctrineTypeMappingFor($dbType) + public function hasDoctrineTypeMappingFor(string $dbType) : bool { if ($this->doctrineTypeMapping === null) { $this->initializeAllDoctrineTypeMappings(); @@ -390,10 +346,8 @@ public function hasDoctrineTypeMappingFor($dbType) /** * Initializes the Doctrine Type comments instance variable for in_array() checks. - * - * @return void */ - protected function initializeCommentedDoctrineTypes() + protected function initializeCommentedDoctrineTypes() : void { $this->doctrineTypeComments = []; @@ -410,10 +364,8 @@ protected function initializeCommentedDoctrineTypes() /** * Is it necessary for the platform to add a parsable type comment to allow reverse engineering the given type? - * - * @return bool */ - public function isCommentedDoctrineType(Type $doctrineType) + public function isCommentedDoctrineType(Type $doctrineType) : bool { if ($this->doctrineTypeComments === null) { $this->initializeCommentedDoctrineTypes(); @@ -428,10 +380,8 @@ public function isCommentedDoctrineType(Type $doctrineType) * Marks this type as to be commented in ALTER TABLE and CREATE TABLE statements. * * @param string|Type $doctrineType - * - * @return void */ - public function markDoctrineTypeCommented($doctrineType) + public function markDoctrineTypeCommented($doctrineType) : void { if ($this->doctrineTypeComments === null) { $this->initializeCommentedDoctrineTypes(); @@ -444,20 +394,16 @@ public function markDoctrineTypeCommented($doctrineType) /** * Gets the comment to append to a column comment that helps parsing this type in reverse engineering. - * - * @return string */ - public function getDoctrineTypeComment(Type $doctrineType) + public function getDoctrineTypeComment(Type $doctrineType) : string { return '(DC2Type:' . $doctrineType->getName() . ')'; } /** * Gets the comment of a passed column modified by potential doctrine type comment hints. - * - * @return string|null */ - protected function getColumnComment(Column $column) + protected function getColumnComment(Column $column) : ?string { $comment = $column->getComment(); @@ -470,30 +416,24 @@ protected function getColumnComment(Column $column) /** * Gets the character used for identifier quoting. - * - * @return string */ - public function getIdentifierQuoteCharacter() + public function getIdentifierQuoteCharacter() : string { return '"'; } /** * Gets the string portion that starts an SQL comment. - * - * @return string */ - public function getSqlCommentStartString() + public function getSqlCommentStartString() : string { return '--'; } /** * Gets the string portion that ends an SQL comment. - * - * @return string */ - public function getSqlCommentEndString() + public function getSqlCommentEndString() : string { return "\n"; } @@ -508,40 +448,32 @@ public function getCharMaxLength() : int /** * Gets the maximum length of a varchar field. - * - * @return int */ - public function getVarcharMaxLength() + public function getVarcharMaxLength() : int { return 4000; } /** * Gets the default length of a varchar field. - * - * @return int */ - public function getVarcharDefaultLength() + public function getVarcharDefaultLength() : int { return 255; } /** * Gets the maximum length of a binary field. - * - * @return int */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 4000; } /** * Gets the default length of a binary field. - * - * @return int */ - public function getBinaryDefaultLength() + public function getBinaryDefaultLength() : int { return 255; } @@ -551,7 +483,7 @@ public function getBinaryDefaultLength() * * @return string[] */ - public function getWildcards() + public function getWildcards() : array { return ['%', '_']; } @@ -1179,10 +1111,8 @@ public function getBitOrComparisonExpression(string $value1, string $value2) : s /** * Returns the FOR UPDATE expression. - * - * @return string */ - public function getForUpdateSQL() + public function getForUpdateSQL() : string { return 'FOR UPDATE'; } @@ -1193,10 +1123,8 @@ public function getForUpdateSQL() * @param string $fromClause The FROM clause to append the hint for the given lock mode to. * @param int|null $lockMode One of the Doctrine\DBAL\LockMode::* constants. If null is given, nothing will * be appended to the FROM clause. - * - * @return string */ - public function appendLockHint($fromClause, $lockMode) + public function appendLockHint(string $fromClause, ?int $lockMode) : string { return $fromClause; } @@ -1206,10 +1134,8 @@ public function appendLockHint($fromClause, $lockMode) * * This defaults to the ANSI SQL "FOR UPDATE", which is an exclusive lock (Write). Some database * vendors allow to lighten this constraint up to be a real read lock. - * - * @return string */ - public function getReadLockSQL() + public function getReadLockSQL() : string { return $this->getForUpdateSQL(); } @@ -1218,10 +1144,8 @@ public function getReadLockSQL() * Returns the SQL snippet to append to any SELECT statement which obtains an exclusive lock on the rows. * * The semantics of this lock mode should equal the SELECT .. FOR UPDATE of the ANSI SQL standard. - * - * @return string */ - public function getWriteLockSQL() + public function getWriteLockSQL() : string { return $this->getForUpdateSQL(); } @@ -1230,10 +1154,8 @@ public function getWriteLockSQL() * Returns the SQL snippet to drop an existing database. * * @param string $database The name of the database that should be dropped. - * - * @return string */ - public function getDropDatabaseSQL($database) + public function getDropDatabaseSQL(string $database) : string { return 'DROP DATABASE ' . $database; } @@ -1243,11 +1165,9 @@ public function getDropDatabaseSQL($database) * * @param Table|string $table * - * @return string - * * @throws InvalidArgumentException */ - public function getDropTableSQL($table) + public function getDropTableSQL($table) : string { $tableArg = $table; @@ -1281,10 +1201,8 @@ public function getDropTableSQL($table) * Returns the SQL to safely drop a temporary table WITHOUT implicitly committing an open transaction. * * @param Table|string $table - * - * @return string */ - public function getDropTemporaryTableSQL($table) + public function getDropTemporaryTableSQL($table) : string { return $this->getDropTableSQL($table); } @@ -1295,11 +1213,9 @@ public function getDropTemporaryTableSQL($table) * @param Index|string $index * @param Table|string $table * - * @return string - * * @throws InvalidArgumentException */ - public function getDropIndexSQL($index, $table = null) + public function getDropIndexSQL($index, $table = null) : string { if ($index instanceof Index) { $index = $index->getQuotedName($this); @@ -1315,10 +1231,8 @@ public function getDropIndexSQL($index, $table = null) * * @param Constraint|string $constraint * @param Table|string $table - * - * @return string */ - public function getDropConstraintSQL($constraint, $table) + public function getDropConstraintSQL($constraint, $table) : string { if (! $constraint instanceof Constraint) { $constraint = new Identifier($constraint); @@ -1339,10 +1253,8 @@ public function getDropConstraintSQL($constraint, $table) * * @param ForeignKeyConstraint|string $foreignKey * @param Table|string $table - * - * @return string */ - public function getDropForeignKeySQL($foreignKey, $table) + public function getDropForeignKeySQL($foreignKey, $table) : string { if (! $foreignKey instanceof ForeignKeyConstraint) { $foreignKey = new Identifier($foreignKey); @@ -1362,19 +1274,12 @@ public function getDropForeignKeySQL($foreignKey, $table) * Returns the SQL statement(s) to create a table with the specified name, columns and constraints * on this platform. * - * @param int $createFlags - * * @return string[] The sequence of SQL statements. * * @throws DBALException - * @throws InvalidArgumentException */ - public function getCreateTableSQL(Table $table, $createFlags = self::CREATE_INDEXES) + public function getCreateTableSQL(Table $table, int $createFlags = self::CREATE_INDEXES) : array { - if (! is_int($createFlags)) { - throw new InvalidArgumentException('Second argument of AbstractPlatform::getCreateTableSQL() has to be an integer.'); - } - if (count($table->getColumns()) === 0) { throw NoColumnsSpecifiedForTable::new($table->getName()); } @@ -1482,14 +1387,7 @@ protected function getCommentOnTableSQL(string $tableName, ?string $comment) : s ); } - /** - * @param string $tableName - * @param string $columnName - * @param string|null $comment - * - * @return string - */ - public function getCommentOnColumnSQL($tableName, $columnName, $comment) + public function getCommentOnColumnSQL(string $tableName, string $columnName, ?string $comment) : string { $tableName = new Identifier($tableName); $columnName = new Identifier($columnName); @@ -1505,31 +1403,26 @@ public function getCommentOnColumnSQL($tableName, $columnName, $comment) /** * Returns the SQL to create inline comment on a column. * - * @param string $comment - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getInlineColumnCommentSQL($comment) + public function getInlineColumnCommentSQL(?string $comment) : string { if (! $this->supportsInlineColumnComments()) { throw NotSupported::new(__METHOD__); } - return 'COMMENT ' . $this->quoteStringLiteral($comment); + return 'COMMENT ' . $this->quoteStringLiteral((string) $comment); } /** * Returns the SQL used to create a table. * - * @param string $tableName * @param mixed[][] $columns * @param mixed[] $options * * @return string[] */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $columnListSql = $this->getColumnDeclarationListSQL($columns); @@ -1568,10 +1461,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options return $sql; } - /** - * @return string - */ - public function getCreateTemporaryTableSnippetSQL() + public function getCreateTemporaryTableSnippetSQL() : string { return 'CREATE TEMPORARY TABLE'; } @@ -1579,11 +1469,9 @@ public function getCreateTemporaryTableSnippetSQL() /** * Returns the SQL to create a sequence on this platform. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getCreateSequenceSQL(Sequence $sequence) + public function getCreateSequenceSQL(Sequence $sequence) : string { throw NotSupported::new(__METHOD__); } @@ -1591,11 +1479,9 @@ public function getCreateSequenceSQL(Sequence $sequence) /** * Returns the SQL to change a sequence on this platform. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getAlterSequenceSQL(Sequence $sequence) + public function getAlterSequenceSQL(Sequence $sequence) : string { throw NotSupported::new(__METHOD__); } @@ -1605,11 +1491,9 @@ public function getAlterSequenceSQL(Sequence $sequence) * * @param Table|string $table * - * @return string - * * @throws InvalidArgumentException */ - public function getCreateConstraintSQL(Constraint $constraint, $table) + public function getCreateConstraintSQL(Constraint $constraint, $table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -1646,11 +1530,9 @@ public function getCreateConstraintSQL(Constraint $constraint, $table) * * @param Table|string $table The name of the table on which the index is to be created. * - * @return string - * * @throws InvalidArgumentException */ - public function getCreateIndexSQL(Index $index, $table) + public function getCreateIndexSQL(Index $index, $table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -1674,10 +1556,8 @@ public function getCreateIndexSQL(Index $index, $table) /** * Adds condition for partial index. - * - * @return string */ - protected function getPartialIndexSQL(Index $index) + protected function getPartialIndexSQL(Index $index) : string { if ($this->supportsPartialIndexes() && $index->hasOption('where')) { return ' WHERE ' . $index->getOption('where'); @@ -1688,10 +1568,8 @@ protected function getPartialIndexSQL(Index $index) /** * Adds additional flags for index generation. - * - * @return string */ - protected function getCreateIndexSQLFlags(Index $index) + protected function getCreateIndexSQLFlags(Index $index) : string { return $index->isUnique() ? 'UNIQUE ' : ''; } @@ -1700,10 +1578,8 @@ protected function getCreateIndexSQLFlags(Index $index) * Returns the SQL to create an unnamed primary key constraint. * * @param Table|string $table - * - * @return string */ - public function getCreatePrimaryKeySQL(Index $index, $table) + public function getCreatePrimaryKeySQL(Index $index, $table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -1715,13 +1591,9 @@ public function getCreatePrimaryKeySQL(Index $index, $table) /** * Returns the SQL to create a named schema. * - * @param string $schemaName - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getCreateSchemaSQL($schemaName) + public function getCreateSchemaSQL(string $schemaName) : string { throw NotSupported::new(__METHOD__); } @@ -1735,19 +1607,19 @@ public function getCreateSchemaSQL($schemaName) * you SHOULD use them. In general, they end up causing way more * problems than they solve. * - * @param string $str The identifier name to be quoted. + * @param string $identifier The identifier name to be quoted. * * @return string The quoted identifier string. */ - public function quoteIdentifier($str) + public function quoteIdentifier(string $identifier) : string { - if (strpos($str, '.') !== false) { - $parts = array_map([$this, 'quoteSingleIdentifier'], explode('.', $str)); + if (strpos($identifier, '.') !== false) { + $parts = array_map([$this, 'quoteSingleIdentifier'], explode('.', $identifier)); return implode('.', $parts); } - return $this->quoteSingleIdentifier($str); + return $this->quoteSingleIdentifier($identifier); } /** @@ -1757,7 +1629,7 @@ public function quoteIdentifier($str) * * @return string The quoted identifier string. */ - public function quoteSingleIdentifier($str) + public function quoteSingleIdentifier(string $str) : string { $c = $this->getIdentifierQuoteCharacter(); @@ -1769,10 +1641,8 @@ public function quoteSingleIdentifier($str) * * @param ForeignKeyConstraint $foreignKey The foreign key constraint. * @param Table|string $table The name of the table on which the foreign key is to be created. - * - * @return string */ - public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) + public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -1790,17 +1660,15 @@ public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) * * @throws DBALException If not supported on this platform. */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { throw NotSupported::new(__METHOD__); } /** * @param mixed[] $columnSql - * - * @return bool */ - protected function onSchemaAlterTableAddColumn(Column $column, TableDiff $diff, &$columnSql) + protected function onSchemaAlterTableAddColumn(Column $column, TableDiff $diff, array &$columnSql) : bool { if ($this->_eventManager === null) { return false; @@ -1820,10 +1688,8 @@ protected function onSchemaAlterTableAddColumn(Column $column, TableDiff $diff, /** * @param string[] $columnSql - * - * @return bool */ - protected function onSchemaAlterTableRemoveColumn(Column $column, TableDiff $diff, &$columnSql) + protected function onSchemaAlterTableRemoveColumn(Column $column, TableDiff $diff, array &$columnSql) : bool { if ($this->_eventManager === null) { return false; @@ -1843,10 +1709,8 @@ protected function onSchemaAlterTableRemoveColumn(Column $column, TableDiff $dif /** * @param string[] $columnSql - * - * @return bool */ - protected function onSchemaAlterTableChangeColumn(ColumnDiff $columnDiff, TableDiff $diff, &$columnSql) + protected function onSchemaAlterTableChangeColumn(ColumnDiff $columnDiff, TableDiff $diff, array &$columnSql) : bool { if ($this->_eventManager === null) { return false; @@ -1865,12 +1729,9 @@ protected function onSchemaAlterTableChangeColumn(ColumnDiff $columnDiff, TableD } /** - * @param string $oldColumnName * @param string[] $columnSql - * - * @return bool */ - protected function onSchemaAlterTableRenameColumn($oldColumnName, Column $column, TableDiff $diff, &$columnSql) + protected function onSchemaAlterTableRenameColumn(string $oldColumnName, Column $column, TableDiff $diff, array &$columnSql) : bool { if ($this->_eventManager === null) { return false; @@ -1890,10 +1751,8 @@ protected function onSchemaAlterTableRenameColumn($oldColumnName, Column $column /** * @param string[] $sql - * - * @return bool */ - protected function onSchemaAlterTable(TableDiff $diff, &$sql) + protected function onSchemaAlterTable(TableDiff $diff, array &$sql) : bool { if ($this->_eventManager === null) { return false; @@ -1914,7 +1773,7 @@ protected function onSchemaAlterTable(TableDiff $diff, &$sql) /** * @return string[] */ - protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) : array { $tableName = $diff->getName($this)->getQuotedName($this); @@ -1941,7 +1800,7 @@ protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) /** * @return string[] */ - protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $newName = $diff->getNewName(); @@ -1990,7 +1849,7 @@ protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) * * @return string[] The sequence of SQL statements for renaming the given index. */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { return [ $this->getDropIndexSQL($oldIndexName, $tableName), @@ -2005,7 +1864,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) * * @return string[] */ - protected function _getAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function _getAlterTableIndexForeignKeySQL(TableDiff $diff) : array { return array_merge($this->getPreAlterTableIndexForeignKeySQL($diff), $this->getPostAlterTableIndexForeignKeySQL($diff)); } @@ -2036,10 +1895,8 @@ protected function _getAlterTableIndexForeignKeySQL(TableDiff $diff) * Text value with the default COLLATION for this field. * unique * unique constraint - * - * @return string */ - public function getColumnDeclarationListSQL(array $fields) + public function getColumnDeclarationListSQL(array $fields) : string { $queryFields = []; @@ -2083,7 +1940,7 @@ public function getColumnDeclarationListSQL(array $fields) * * @return string DBMS specific SQL code portion that should be used to declare the column. */ - public function getColumnDeclarationSQL($name, array $field) + public function getColumnDeclarationSQL(string $name, array $field) : string { if (isset($field['columnDefinition'])) { $columnDef = $this->getCustomTypeDeclarationSQL($field); @@ -2119,10 +1976,8 @@ public function getColumnDeclarationSQL($name, array $field) * Returns the SQL snippet that declares a floating point column of arbitrary precision. * * @param mixed[] $columnDef - * - * @return string */ - public function getDecimalTypeDeclarationSQL(array $columnDef) + public function getDecimalTypeDeclarationSQL(array $columnDef) : string { $columnDef['precision'] = ! isset($columnDef['precision']) || empty($columnDef['precision']) ? 10 : $columnDef['precision']; @@ -2140,7 +1995,7 @@ public function getDecimalTypeDeclarationSQL(array $columnDef) * * @return string DBMS specific SQL code portion needed to set a default value. */ - public function getDefaultValueDeclarationSQL($field) + public function getDefaultValueDeclarationSQL(array $field) : string { if (! isset($field['default'])) { return empty($field['notnull']) ? ' DEFAULT NULL' : ''; @@ -2174,6 +2029,10 @@ public function getDefaultValueDeclarationSQL($field) return " DEFAULT '" . $this->convertBooleans($default) . "'"; } + if (is_int($default) || is_float($default)) { + return ' DEFAULT ' . $default; + } + return ' DEFAULT ' . $this->quoteStringLiteral($default); } @@ -2185,7 +2044,7 @@ public function getDefaultValueDeclarationSQL($field) * * @return string DBMS specific SQL code portion needed to set a CHECK constraint. */ - public function getCheckDeclarationSQL(array $definition) + public function getCheckDeclarationSQL(array $definition) : string { $constraints = []; foreach ($definition as $field => $def) { @@ -2196,9 +2055,11 @@ public function getCheckDeclarationSQL(array $definition) $constraints[] = 'CHECK (' . $field . ' >= ' . $def['min'] . ')'; } - if (isset($def['max'])) { - $constraints[] = 'CHECK (' . $field . ' <= ' . $def['max'] . ')'; + if (! isset($def['max'])) { + continue; } + + $constraints[] = 'CHECK (' . $field . ' <= ' . $def['max'] . ')'; } } @@ -2216,26 +2077,29 @@ public function getCheckDeclarationSQL(array $definition) * * @throws InvalidArgumentException */ - public function getUniqueConstraintDeclarationSQL($name, UniqueConstraint $constraint) + public function getUniqueConstraintDeclarationSQL(string $name, UniqueConstraint $constraint) : string { $columns = $constraint->getColumns(); - $name = new Identifier($name); if (count($columns) === 0) { throw new InvalidArgumentException('Incomplete definition. "columns" required.'); } - $flags = ['UNIQUE']; + $chunks = ['CONSTRAINT']; + + if ($name !== '') { + $chunks[] = (new Identifier($name))->getQuotedName($this); + } + + $chunks[] = 'UNIQUE'; if ($constraint->hasFlag('clustered')) { - $flags[] = 'CLUSTERED'; + $chunks[] = 'CLUSTERED'; } - $constraintName = $name->getQuotedName($this); - $constraintName = ! empty($constraintName) ? $constraintName . ' ' : ''; - $columnListNames = $this->getIndexFieldDeclarationListSQL($columns); + $chunks[] = sprintf('(%s)', $this->getIndexFieldDeclarationListSQL($columns)); - return sprintf('CONSTRAINT %s%s (%s)', $constraintName, implode(' ', $flags), $columnListNames); + return implode(' ', $chunks); } /** @@ -2249,7 +2113,7 @@ public function getUniqueConstraintDeclarationSQL($name, UniqueConstraint $const * * @throws InvalidArgumentException */ - public function getIndexDeclarationSQL($name, Index $index) + public function getIndexDeclarationSQL(string $name, Index $index) : string { $columns = $index->getColumns(); $name = new Identifier($name); @@ -2269,10 +2133,8 @@ public function getIndexDeclarationSQL($name, Index $index) * Only "AUTOINCREMENT" and "PRIMARY KEY" are added if appropriate. * * @param mixed[] $columnDef - * - * @return string */ - public function getCustomTypeDeclarationSQL(array $columnDef) + public function getCustomTypeDeclarationSQL(array $columnDef) : string { return $columnDef['columnDefinition']; } @@ -2320,19 +2182,15 @@ public function getIndexFieldDeclarationListSQL($columnsOrIndex) : string * @return string The string required to be placed between "CREATE" and "TABLE" * to generate a temporary table, if possible. */ - public function getTemporaryTableSQL() + public function getTemporaryTableSQL() : string { return 'TEMPORARY'; } /** * Some vendors require temporary table names to be qualified specially. - * - * @param string $tableName - * - * @return string */ - public function getTemporaryTableName($tableName) + public function getTemporaryTableName(string $tableName) : string { return $tableName; } @@ -2344,7 +2202,7 @@ public function getTemporaryTableName($tableName) * @return string DBMS specific SQL code portion needed to set the FOREIGN KEY constraint * of a field declaration. */ - public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) + public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) : string { $sql = $this->getForeignKeyBaseDeclarationSQL($foreignKey); $sql .= $this->getAdvancedForeignKeyOptionsSQL($foreignKey); @@ -2357,10 +2215,8 @@ public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) * as MATCH, INITIALLY DEFERRED, ON UPDATE, ... * * @param ForeignKeyConstraint $foreignKey The foreign key definition. - * - * @return string */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $query = ''; if ($this->supportsForeignKeyOnUpdate() && $foreignKey->hasOption('onUpdate')) { @@ -2378,11 +2234,9 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey * * @param string $action The foreign key referential action. * - * @return string - * * @throws InvalidArgumentException If unknown referential action given. */ - public function getForeignKeyReferentialActionSQL($action) + public function getForeignKeyReferentialActionSQL(string $action) : string { $upper = strtoupper($action); switch ($upper) { @@ -2401,14 +2255,12 @@ public function getForeignKeyReferentialActionSQL($action) * Obtains DBMS specific SQL code portion needed to set the FOREIGN KEY constraint * of a field declaration to be used in statements like CREATE TABLE. * - * @return string - * * @throws InvalidArgumentException */ - public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey) + public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey) : string { $sql = ''; - if (strlen($foreignKey->getName())) { + if ($foreignKey->getName() !== '') { $sql .= 'CONSTRAINT ' . $foreignKey->getQuotedName($this) . ' '; } $sql .= 'FOREIGN KEY ('; @@ -2436,7 +2288,7 @@ public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey * @return string DBMS specific SQL code portion needed to set the UNIQUE constraint * of a field declaration. */ - public function getUniqueFieldDeclarationSQL() + public function getUniqueFieldDeclarationSQL() : string { return 'UNIQUE'; } @@ -2450,7 +2302,7 @@ public function getUniqueFieldDeclarationSQL() * @return string DBMS specific SQL code portion needed to set the CHARACTER SET * of a field declaration. */ - public function getColumnCharsetDeclarationSQL($charset) + public function getColumnCharsetDeclarationSQL(string $charset) : string { return ''; } @@ -2464,7 +2316,7 @@ public function getColumnCharsetDeclarationSQL($charset) * @return string DBMS specific SQL code portion needed to set the COLLATION * of a field declaration. */ - public function getColumnCollationDeclarationSQL($collation) + public function getColumnCollationDeclarationSQL(string $collation) : string { return $this->supportsColumnCollation() ? 'COLLATE ' . $collation : ''; } @@ -2472,10 +2324,8 @@ public function getColumnCollationDeclarationSQL($collation) /** * Whether the platform prefers sequences for ID generation. * Subclasses should override this method to return TRUE if they prefer sequences. - * - * @return bool */ - public function prefersSequences() + public function prefersSequences() : bool { return false; } @@ -2483,10 +2333,8 @@ public function prefersSequences() /** * Whether the platform prefers identity columns (eg. autoincrement) for ID generation. * Subclasses should override this method to return TRUE if they prefer identity columns. - * - * @return bool */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return false; } @@ -2528,12 +2376,14 @@ public function convertBooleans($item) * The default conversion tries to convert value into bool "(bool)$item" * * @param mixed $item - * - * @return bool|null */ - public function convertFromBoolean($item) + public function convertFromBoolean($item) : ?bool { - return $item === null ? null: (bool) $item; + if ($item === null) { + return null; + } + + return (bool) $item; } /** @@ -2553,30 +2403,24 @@ public function convertBooleansToDatabaseValue($item) /** * Returns the SQL specific for the platform to get the current date. - * - * @return string */ - public function getCurrentDateSQL() + public function getCurrentDateSQL() : string { return 'CURRENT_DATE'; } /** * Returns the SQL specific for the platform to get the current time. - * - * @return string */ - public function getCurrentTimeSQL() + public function getCurrentTimeSQL() : string { return 'CURRENT_TIME'; } /** * Returns the SQL specific for the platform to get the current timestamp - * - * @return string */ - public function getCurrentTimestampSQL() + public function getCurrentTimestampSQL() : string { return 'CURRENT_TIMESTAMP'; } @@ -2584,13 +2428,9 @@ public function getCurrentTimestampSQL() /** * Returns the SQL for a given transaction isolation level Connection constant. * - * @param int $level - * - * @return string - * * @throws InvalidArgumentException */ - protected function _getTransactionIsolationLevelSQL($level) + protected function _getTransactionIsolationLevelSQL(int $level) : string { switch ($level) { case TransactionIsolationLevel::READ_UNCOMMITTED: @@ -2607,11 +2447,9 @@ protected function _getTransactionIsolationLevelSQL($level) } /** - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { throw NotSupported::new(__METHOD__); } @@ -2619,68 +2457,49 @@ public function getListDatabasesSQL() /** * Returns the SQL statement for retrieving the namespaces defined in the database. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListNamespacesSQL() + public function getListNamespacesSQL() : string { throw NotSupported::new(__METHOD__); } /** - * @param string $database - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListSequencesSQL($database) + public function getListSequencesSQL(string $database) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $table - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $table - * @param string|null $database - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { throw NotSupported::new(__METHOD__); } /** - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListTablesSQL() + public function getListTablesSQL() : string { throw NotSupported::new(__METHOD__); } /** - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListUsersSQL() + public function getListUsersSQL() : string { throw NotSupported::new(__METHOD__); } @@ -2688,13 +2507,9 @@ public function getListUsersSQL() /** * Returns the SQL to list all views of a database or user. * - * @param string $database - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { throw NotSupported::new(__METHOD__); } @@ -2709,51 +2524,33 @@ public function getListViewsSQL($database) * are connected with that database. Cross-database information schema * requests may be impossible. * - * @param string $table - * @param string $currentDatabase - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $table - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getListTableForeignKeysSQL($table) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $name - * @param string $sql - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $name - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { throw NotSupported::new(__METHOD__); } @@ -2763,23 +2560,17 @@ public function getDropViewSQL($name) * * @param Sequence|string $sequence * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getDropSequenceSQL($sequence) + public function getDropSequenceSQL($sequence) : string { throw NotSupported::new(__METHOD__); } /** - * @param string $sequenceName - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getSequenceNextValSQL($sequenceName) + public function getSequenceNextValSQL(string $sequenceName) : string { throw NotSupported::new(__METHOD__); } @@ -2789,11 +2580,9 @@ public function getSequenceNextValSQL($sequenceName) * * @param string $database The name of the database that should be created. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getCreateDatabaseSQL($database) + public function getCreateDatabaseSQL(string $database) : string { throw NotSupported::new(__METHOD__); } @@ -2801,13 +2590,9 @@ public function getCreateDatabaseSQL($database) /** * Returns the SQL to set the transaction isolation level. * - * @param int $level - * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { throw NotSupported::new(__METHOD__); } @@ -2818,11 +2603,9 @@ public function getSetTransactionIsolationSQL($level) * * @param mixed[] $fieldDeclaration * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { throw NotSupported::new(__METHOD__); } @@ -2831,10 +2614,8 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) * Obtains DBMS specific SQL to be used to create datetime with timezone offset fields. * * @param mixed[] $fieldDeclaration - * - * @return string */ - public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) : string { return $this->getDateTimeTypeDeclarationSQL($fieldDeclaration); } @@ -2845,11 +2626,9 @@ public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) * * @param mixed[] $fieldDeclaration * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { throw NotSupported::new(__METHOD__); } @@ -2860,21 +2639,17 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) * * @param mixed[] $fieldDeclaration * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { throw NotSupported::new(__METHOD__); } /** * @param mixed[] $fieldDeclaration - * - * @return string */ - public function getFloatDeclarationSQL(array $fieldDeclaration) + public function getFloatDeclarationSQL(array $fieldDeclaration) : string { return 'DOUBLE PRECISION'; } @@ -2886,7 +2661,7 @@ public function getFloatDeclarationSQL(array $fieldDeclaration) * * @return int The default isolation level. */ - public function getDefaultTransactionIsolationLevel() + public function getDefaultTransactionIsolationLevel() : int { return TransactionIsolationLevel::READ_COMMITTED; } @@ -2895,10 +2670,8 @@ public function getDefaultTransactionIsolationLevel() /** * Whether the platform supports sequences. - * - * @return bool */ - public function supportsSequences() + public function supportsSequences() : bool { return false; } @@ -2908,10 +2681,8 @@ public function supportsSequences() * * Identity columns are columns that receive an auto-generated value from the * database on insert of a row. - * - * @return bool */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return false; } @@ -2922,23 +2693,16 @@ public function supportsIdentityColumns() * Some platforms that do not support identity columns natively * but support sequences can emulate identity columns by using * sequences. - * - * @return bool */ - public function usesSequenceEmulatedIdentityColumns() + public function usesSequenceEmulatedIdentityColumns() : bool { return false; } /** * Gets the sequence name prefix based on table information. - * - * @param string $tableName - * @param string|null $schemaName - * - * @return string */ - public function getSequencePrefix($tableName, $schemaName = null) + public function getSequencePrefix(string $tableName, ?string $schemaName = null) : string { if (! $schemaName) { return $tableName; @@ -2958,31 +2722,25 @@ public function getSequencePrefix($tableName, $schemaName = null) * @param string $tableName The name of the table to return the sequence name for. * @param string $columnName The name of the identity column in the table to return the sequence name for. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getIdentitySequenceName($tableName, $columnName) + public function getIdentitySequenceName(string $tableName, string $columnName) : string { throw NotSupported::new(__METHOD__); } /** * Whether the platform supports indexes. - * - * @return bool */ - public function supportsIndexes() + public function supportsIndexes() : bool { return true; } /** * Whether the platform supports partial indexes. - * - * @return bool */ - public function supportsPartialIndexes() + public function supportsPartialIndexes() : bool { return false; } @@ -2997,80 +2755,64 @@ public function supportsColumnLengthIndexes() : bool /** * Whether the platform supports altering tables. - * - * @return bool */ - public function supportsAlterTable() + public function supportsAlterTable() : bool { return true; } /** * Whether the platform supports transactions. - * - * @return bool */ - public function supportsTransactions() + public function supportsTransactions() : bool { return true; } /** * Whether the platform supports savepoints. - * - * @return bool */ - public function supportsSavepoints() + public function supportsSavepoints() : bool { return true; } /** * Whether the platform supports releasing savepoints. - * - * @return bool */ - public function supportsReleaseSavepoints() + public function supportsReleaseSavepoints() : bool { return $this->supportsSavepoints(); } /** * Whether the platform supports primary key constraints. - * - * @return bool */ - public function supportsPrimaryConstraints() + public function supportsPrimaryConstraints() : bool { return true; } /** * Whether the platform supports foreign key constraints. - * - * @return bool */ - public function supportsForeignKeyConstraints() + public function supportsForeignKeyConstraints() : bool { return true; } /** * Whether this platform supports onUpdate in foreign key constraints. - * - * @return bool */ - public function supportsForeignKeyOnUpdate() + public function supportsForeignKeyOnUpdate() : bool { return $this->supportsForeignKeyConstraints(); } /** * Whether the platform supports database schemas. - * - * @return bool */ - public function supportsSchemas() + public function supportsSchemas() : bool { return false; } @@ -3081,10 +2823,8 @@ public function supportsSchemas() * Platforms that either support or emulate schemas don't automatically * filter a schema for the namespaced elements in {@link * AbstractManager#createSchema}. - * - * @return bool */ - public function canEmulateSchemas() + public function canEmulateSchemas() : bool { return false; } @@ -3092,11 +2832,9 @@ public function canEmulateSchemas() /** * Returns the default schema name. * - * @return string - * * @throws DBALException If not supported on this platform. */ - public function getDefaultSchemaName() + public function getDefaultSchemaName() : string { throw NotSupported::new(__METHOD__); } @@ -3105,80 +2843,64 @@ public function getDefaultSchemaName() * Whether this platform supports create database. * * Some databases don't allow to create and drop databases at all or only with certain tools. - * - * @return bool */ - public function supportsCreateDropDatabase() + public function supportsCreateDropDatabase() : bool { return true; } /** * Whether the platform supports getting the affected rows of a recent update/delete type query. - * - * @return bool */ - public function supportsGettingAffectedRows() + public function supportsGettingAffectedRows() : bool { return true; } /** * Whether this platform support to add inline column comments as postfix. - * - * @return bool */ - public function supportsInlineColumnComments() + public function supportsInlineColumnComments() : bool { return false; } /** * Whether this platform support the proprietary syntax "COMMENT ON asset". - * - * @return bool */ - public function supportsCommentOnStatement() + public function supportsCommentOnStatement() : bool { return false; } /** * Does this platform have native guid type. - * - * @return bool */ - public function hasNativeGuidType() + public function hasNativeGuidType() : bool { return false; } /** * Does this platform have native JSON type. - * - * @return bool */ - public function hasNativeJsonType() + public function hasNativeJsonType() : bool { return false; } /** * Whether this platform supports views. - * - * @return bool */ - public function supportsViews() + public function supportsViews() : bool { return true; } /** * Does this platform support column collation? - * - * @return bool */ - public function supportsColumnCollation() + public function supportsColumnCollation() : bool { return false; } @@ -3189,7 +2911,7 @@ public function supportsColumnCollation() * * @return string The format string. */ - public function getDateTimeFormatString() + public function getDateTimeFormatString() : string { return 'Y-m-d H:i:s'; } @@ -3200,7 +2922,7 @@ public function getDateTimeFormatString() * * @return string The format string. */ - public function getDateTimeTzFormatString() + public function getDateTimeTzFormatString() : string { return 'Y-m-d H:i:s'; } @@ -3211,7 +2933,7 @@ public function getDateTimeTzFormatString() * * @return string The format string. */ - public function getDateFormatString() + public function getDateFormatString() : string { return 'Y-m-d'; } @@ -3222,7 +2944,7 @@ public function getDateFormatString() * * @return string The format string. */ - public function getTimeFormatString() + public function getTimeFormatString() : string { return 'H:i:s'; } @@ -3269,10 +2991,8 @@ protected function doModifyLimitQuery(string $query, ?int $limit, int $offset) : /** * Whether the database platform support offsets in modify limit clauses. - * - * @return bool */ - public function supportsLimitOffset() + public function supportsLimitOffset() : bool { return true; } @@ -3284,7 +3004,7 @@ public function supportsLimitOffset() * * @return string The column name in the character casing used in SQL result sets. */ - public function getSQLResultCasing($column) + public function getSQLResultCasing(string $column) : string { return $column; } @@ -3292,35 +3012,24 @@ public function getSQLResultCasing($column) /** * Makes any fixes to a name of a schema element (table, sequence, ...) that are required * by restrictions of the platform, like a maximum length. - * - * @param string $schemaElementName - * - * @return string */ - public function fixSchemaElementName($schemaElementName) + public function fixSchemaElementName(string $schemaElementName) : string { return $schemaElementName; } /** * Maximum length of any given database identifier, like tables or column names. - * - * @return int */ - public function getMaxIdentifierLength() + public function getMaxIdentifierLength() : int { return 63; } /** * Returns the insert SQL for an empty insert statement. - * - * @param string $tableName - * @param string $identifierColumnName - * - * @return string */ - public function getEmptyIdentityInsertSQL($tableName, $identifierColumnName) + public function getEmptyIdentityInsertSQL(string $tableName, string $identifierColumnName) : string { return 'INSERT INTO ' . $tableName . ' (' . $identifierColumnName . ') VALUES (null)'; } @@ -3330,13 +3039,8 @@ public function getEmptyIdentityInsertSQL($tableName, $identifierColumnName) * * Cascade is not supported on many platforms but would optionally cascade the truncate by * following the foreign keys. - * - * @param string $tableName - * @param bool $cascade - * - * @return string */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); @@ -3353,36 +3057,24 @@ public function getDummySelectSQL(string $expression = '1') : string /** * Returns the SQL to create a new savepoint. - * - * @param string $savepoint - * - * @return string */ - public function createSavePoint($savepoint) + public function createSavePoint(string $savepoint) : string { return 'SAVEPOINT ' . $savepoint; } /** * Returns the SQL to release a savepoint. - * - * @param string $savepoint - * - * @return string */ - public function releaseSavePoint($savepoint) + public function releaseSavePoint(string $savepoint) : string { return 'RELEASE SAVEPOINT ' . $savepoint; } /** * Returns the SQL to rollback a savepoint. - * - * @param string $savepoint - * - * @return string */ - public function rollbackSavePoint($savepoint) + public function rollbackSavePoint(string $savepoint) : string { return 'ROLLBACK TO SAVEPOINT ' . $savepoint; } @@ -3390,11 +3082,9 @@ public function rollbackSavePoint($savepoint) /** * Returns the keyword list instance of this platform. * - * @return KeywordList - * * @throws DBALException If no keyword list is specified. */ - final public function getReservedKeywordsList() + final public function getReservedKeywordsList() : KeywordList { // Check for an existing instantiation of the keywords class. if ($this->_keywords) { @@ -3416,11 +3106,9 @@ final public function getReservedKeywordsList() /** * Returns the class name of the reserved keywords list. * - * @return string - * * @throws DBALException If not supported on this platform. */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { throw NotSupported::new(__METHOD__); } @@ -3435,7 +3123,7 @@ protected function getReservedKeywordsClass() * * @return string The quoted literal string. */ - public function quoteStringLiteral($str) + public function quoteStringLiteral(string $str) : string { $c = $this->getStringLiteralQuoteCharacter(); @@ -3444,10 +3132,8 @@ public function quoteStringLiteral($str) /** * Gets the character used for string literal quoting. - * - * @return string */ - public function getStringLiteralQuoteCharacter() + public function getStringLiteralQuoteCharacter() : string { return "'"; } diff --git a/lib/Doctrine/DBAL/Platforms/DB2Platform.php b/lib/Doctrine/DBAL/Platforms/DB2Platform.php index d8816dafca4..0666f53c096 100644 --- a/lib/Doctrine/DBAL/Platforms/DB2Platform.php +++ b/lib/Doctrine/DBAL/Platforms/DB2Platform.php @@ -33,7 +33,7 @@ public function getCharMaxLength() : int /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 32704; } @@ -41,7 +41,7 @@ public function getBinaryMaxLength() /** * {@inheritdoc} */ - public function getBinaryDefaultLength() + public function getBinaryDefaultLength() : int { return 1; } @@ -49,7 +49,7 @@ public function getBinaryDefaultLength() /** * {@inheritDoc} */ - public function getVarcharTypeDeclarationSQL(array $field) + public function getVarcharTypeDeclarationSQL(array $field) : string { // for IBM DB2, the CHAR max length is less than VARCHAR default length if (! isset($field['length']) && ! empty($field['fixed'])) { @@ -62,7 +62,7 @@ public function getVarcharTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { // todo blob(n) with $field['length']; return 'BLOB(1M)'; @@ -71,7 +71,7 @@ public function getBlobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function initializeDoctrineTypeMappings() + public function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', @@ -95,7 +95,7 @@ public function initializeDoctrineTypeMappings() /** * {@inheritdoc} */ - public function isCommentedDoctrineType(Type $doctrineType) + public function isCommentedDoctrineType(Type $doctrineType) : bool { if ($doctrineType->getName() === Types::BOOLEAN) { // We require a commented boolean type in order to distinguish between boolean and smallint @@ -109,7 +109,7 @@ public function isCommentedDoctrineType(Type $doctrineType) /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(254)') : ($length ? 'VARCHAR(' . $length . ')' : 'VARCHAR(255)'); @@ -118,7 +118,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $this->getVarcharTypeDeclarationSQLSnippet($length, $fixed) . ' FOR BIT DATA'; } @@ -126,7 +126,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { // todo clob(n) with $field['length']; return 'CLOB(1M)'; @@ -135,7 +135,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'db2'; } @@ -143,7 +143,7 @@ public function getName() /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $columnDef) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'SMALLINT'; } @@ -151,7 +151,7 @@ public function getBooleanTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $columnDef) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { return 'INTEGER' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } @@ -159,7 +159,7 @@ public function getIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $columnDef) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } @@ -167,7 +167,7 @@ public function getBigIntTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $columnDef) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } @@ -175,7 +175,7 @@ public function getSmallIntTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { $autoinc = ''; if (! empty($columnDef['autoincrement'])) { @@ -232,7 +232,7 @@ public function getDateDiffExpression(string $date1, string $date2) : string /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { if (isset($fieldDeclaration['version']) && $fieldDeclaration['version'] === true) { return 'TIMESTAMP(0) WITH DEFAULT'; @@ -244,7 +244,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -252,7 +252,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME'; } @@ -260,7 +260,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritdoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); @@ -269,13 +269,8 @@ public function getTruncateTableSQL($tableName, $cascade = false) /** * This code fragment is originally from the Zend_Db_Adapter_Db2 class, but has been edited. - * - * @param string $table - * @param string $database - * - * @return string */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { $table = $this->quoteStringLiteral($table); @@ -326,7 +321,7 @@ public function getListTableColumnsSQL($table, $database = null) /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return "SELECT NAME FROM SYSIBM.SYSTABLES WHERE TYPE = 'T'"; } @@ -334,7 +329,7 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return 'SELECT NAME, TEXT FROM SYSIBM.SYSVIEWS'; } @@ -342,7 +337,7 @@ public function getListViewsSQL($database) /** * {@inheritDoc} */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { $table = $this->quoteStringLiteral($table); @@ -366,7 +361,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { $table = $this->quoteStringLiteral($table); @@ -400,7 +395,7 @@ public function getListTableForeignKeysSQL($table) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -408,7 +403,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -416,7 +411,7 @@ public function getDropViewSQL($name) /** * {@inheritDoc} */ - public function getCreateDatabaseSQL($database) + public function getCreateDatabaseSQL(string $database) : string { return 'CREATE DATABASE ' . $database; } @@ -424,7 +419,7 @@ public function getCreateDatabaseSQL($database) /** * {@inheritDoc} */ - public function getDropDatabaseSQL($database) + public function getDropDatabaseSQL(string $database) : string { return 'DROP DATABASE ' . $database; } @@ -432,7 +427,7 @@ public function getDropDatabaseSQL($database) /** * {@inheritDoc} */ - public function supportsCreateDropDatabase() + public function supportsCreateDropDatabase() : bool { return false; } @@ -440,7 +435,7 @@ public function supportsCreateDropDatabase() /** * {@inheritDoc} */ - public function supportsReleaseSavepoints() + public function supportsReleaseSavepoints() : bool { return false; } @@ -448,7 +443,7 @@ public function supportsReleaseSavepoints() /** * {@inheritdoc} */ - public function supportsCommentOnStatement() + public function supportsCommentOnStatement() : bool { return true; } @@ -456,7 +451,7 @@ public function supportsCommentOnStatement() /** * {@inheritDoc} */ - public function getCurrentDateSQL() + public function getCurrentDateSQL() : string { return 'CURRENT DATE'; } @@ -464,7 +459,7 @@ public function getCurrentDateSQL() /** * {@inheritDoc} */ - public function getCurrentTimeSQL() + public function getCurrentTimeSQL() : string { return 'CURRENT TIME'; } @@ -472,7 +467,7 @@ public function getCurrentTimeSQL() /** * {@inheritDoc} */ - public function getCurrentTimestampSQL() + public function getCurrentTimestampSQL() : string { return 'CURRENT TIMESTAMP'; } @@ -480,7 +475,7 @@ public function getCurrentTimestampSQL() /** * {@inheritDoc} */ - public function getIndexDeclarationSQL($name, Index $index) + public function getIndexDeclarationSQL(string $name, Index $index) : string { // Index declaration in statements like CREATE TABLE is not supported. throw NotSupported::new(__METHOD__); @@ -489,7 +484,7 @@ public function getIndexDeclarationSQL($name, Index $index) /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $indexes = []; if (isset($options['indexes'])) { @@ -509,7 +504,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $sql = []; $columnSql = []; @@ -628,7 +623,7 @@ public function getAlterTableSQL(TableDiff $diff) * @param string[] $sql The sequence of table alteration statements to fill. * @param mixed[] $queryParts The sequence of column alteration clauses to fill. */ - private function gatherAlterColumnSQL(Identifier $table, ColumnDiff $columnDiff, array &$sql, array &$queryParts) + private function gatherAlterColumnSQL(Identifier $table, ColumnDiff $columnDiff, array &$sql, array &$queryParts) : void { $alterColumnClauses = $this->getAlterColumnClausesSQL($columnDiff); @@ -658,7 +653,7 @@ private function gatherAlterColumnSQL(Identifier $table, ColumnDiff $columnDiff, * * @return string[] */ - private function getAlterColumnClausesSQL(ColumnDiff $columnDiff) + private function getAlterColumnClausesSQL(ColumnDiff $columnDiff) : array { $column = $columnDiff->column->toArray(); @@ -701,7 +696,7 @@ private function getAlterColumnClausesSQL(ColumnDiff $columnDiff) /** * {@inheritDoc} */ - protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $table = $diff->getName($this)->getQuotedName($this); @@ -734,7 +729,7 @@ protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { if (strpos($tableName, '.') !== false) { [$schema] = explode('.', $tableName); @@ -747,7 +742,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) /** * {@inheritDoc} */ - public function getDefaultValueDeclarationSQL($field) + public function getDefaultValueDeclarationSQL(array $field) : string { if (! empty($field['autoincrement'])) { return ''; @@ -765,7 +760,7 @@ public function getDefaultValueDeclarationSQL($field) /** * {@inheritDoc} */ - public function getEmptyIdentityInsertSQL($tableName, $identifierColumnName) + public function getEmptyIdentityInsertSQL(string $tableName, string $identifierColumnName) : string { return 'INSERT INTO ' . $tableName . ' (' . $identifierColumnName . ') VALUES (DEFAULT)'; } @@ -773,7 +768,7 @@ public function getEmptyIdentityInsertSQL($tableName, $identifierColumnName) /** * {@inheritDoc} */ - public function getCreateTemporaryTableSnippetSQL() + public function getCreateTemporaryTableSnippetSQL() : string { return 'DECLARE GLOBAL TEMPORARY TABLE'; } @@ -781,7 +776,7 @@ public function getCreateTemporaryTableSnippetSQL() /** * {@inheritDoc} */ - public function getTemporaryTableName($tableName) + public function getTemporaryTableName(string $tableName) : string { return 'SESSION.' . $tableName; } @@ -840,7 +835,7 @@ public function getSubstringExpression(string $string, string $start, ?string $l /** * {@inheritDoc} */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -848,7 +843,7 @@ public function supportsIdentityColumns() /** * {@inheritDoc} */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return true; } @@ -858,7 +853,7 @@ public function prefersIdentityColumns() * * DB2 returns all column names in SQL result sets in uppercase. */ - public function getSQLResultCasing($column) + public function getSQLResultCasing(string $column) : string { return strtoupper($column); } @@ -866,7 +861,7 @@ public function getSQLResultCasing($column) /** * {@inheritDoc} */ - public function getForUpdateSQL() + public function getForUpdateSQL() : string { return ' WITH RR USE AND KEEP UPDATE LOCKS'; } @@ -886,7 +881,7 @@ public function getDummySelectSQL(string $expression = '1') : string * * TODO: We have to investigate how to get DB2 up and running with savepoints. */ - public function supportsSavepoints() + public function supportsSavepoints() : bool { return false; } @@ -894,7 +889,7 @@ public function supportsSavepoints() /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\DB2Keywords::class; } diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/DB2Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/DB2Keywords.php index 1327ffbeee2..48ca59f6973 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/DB2Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/DB2Keywords.php @@ -12,7 +12,7 @@ class DB2Keywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'DB2'; } @@ -20,7 +20,7 @@ public function getName() /** * {@inheritdoc} */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ACTIVATE', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/KeywordList.php b/lib/Doctrine/DBAL/Platforms/Keywords/KeywordList.php index 251722313ff..b3f4e1dbf01 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/KeywordList.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/KeywordList.php @@ -18,12 +18,8 @@ abstract class KeywordList /** * Checks if the given word is a keyword of this dialect/vendor platform. - * - * @param string $word - * - * @return bool */ - public function isKeyword($word) + public function isKeyword(string $word) : bool { if ($this->keywords === null) { $this->initializeKeywords(); @@ -32,10 +28,7 @@ public function isKeyword($word) return isset($this->keywords[strtoupper($word)]); } - /** - * @return void - */ - protected function initializeKeywords() + protected function initializeKeywords() : void { $this->keywords = array_flip(array_map('strtoupper', $this->getKeywords())); } @@ -45,12 +38,10 @@ protected function initializeKeywords() * * @return string[] */ - abstract protected function getKeywords(); + abstract protected function getKeywords() : array; /** * Returns the name of this keyword list. - * - * @return string */ - abstract public function getName(); + abstract public function getName() : string; } diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php index eda315f58cd..4243d181350 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php @@ -12,7 +12,7 @@ class MySQL57Keywords extends MySQLKeywords /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'MySQL57'; } @@ -22,7 +22,7 @@ public function getName() * * @link http://dev.mysql.com/doc/mysqld-version-reference/en/mysqld-version-reference-reservedwords-5-7.html */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ACCESSIBLE', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL80Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL80Keywords.php index 566a55552a6..7877eba0670 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL80Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL80Keywords.php @@ -14,7 +14,7 @@ class MySQL80Keywords extends MySQL57Keywords /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'MySQL80'; } @@ -24,7 +24,7 @@ public function getName() * * @link https://dev.mysql.com/doc/refman/8.0/en/keywords.html */ - protected function getKeywords() + protected function getKeywords() : array { $keywords = parent::getKeywords(); diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/MySQLKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/MySQLKeywords.php index 9ec94c2df61..8a2b4ababed 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/MySQLKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/MySQLKeywords.php @@ -12,7 +12,7 @@ class MySQLKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'MySQL'; } @@ -20,7 +20,7 @@ public function getName() /** * {@inheritdoc} */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ACCESSIBLE', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/OracleKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/OracleKeywords.php index c134693a6ba..d7f107ea8ee 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/OracleKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/OracleKeywords.php @@ -12,7 +12,7 @@ class OracleKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'Oracle'; } @@ -20,7 +20,7 @@ public function getName() /** * {@inheritdoc} */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ACCESS', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQL94Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQL94Keywords.php index 421819544f3..f9244bb33d6 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQL94Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQL94Keywords.php @@ -15,7 +15,7 @@ class PostgreSQL94Keywords extends PostgreSQLKeywords /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'PostgreSQL94'; } @@ -25,7 +25,7 @@ public function getName() * * @link http://www.postgresql.org/docs/9.4/static/sql-keywords-appendix.html */ - protected function getKeywords() + protected function getKeywords() : array { $parentKeywords = array_diff(parent::getKeywords(), ['OVER']); diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQLKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQLKeywords.php index 017b4e02f63..862b81dfea0 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQLKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/PostgreSQLKeywords.php @@ -12,7 +12,7 @@ class PostgreSQLKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'PostgreSQL'; } @@ -20,7 +20,7 @@ public function getName() /** * {@inheritdoc} */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ALL', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/ReservedKeywordsValidator.php b/lib/Doctrine/DBAL/Platforms/Keywords/ReservedKeywordsValidator.php index 4aab336d10e..2a047f0dc77 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/ReservedKeywordsValidator.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/ReservedKeywordsValidator.php @@ -33,17 +33,15 @@ public function __construct(array $keywordLists) /** * @return string[] */ - public function getViolations() + public function getViolations() : array { return $this->violations; } /** - * @param string $word - * * @return string[] */ - private function isReservedWord($word) + private function isReservedWord(string $word) : array { if ($word[0] === '`') { $word = str_replace('`', '', $word); @@ -62,12 +60,9 @@ private function isReservedWord($word) } /** - * @param string $asset * @param string[] $violatedPlatforms - * - * @return void */ - private function addViolation($asset, $violatedPlatforms) + private function addViolation(string $asset, array $violatedPlatforms) : void { if (! $violatedPlatforms) { return; @@ -79,7 +74,7 @@ private function addViolation($asset, $violatedPlatforms) /** * {@inheritdoc} */ - public function acceptColumn(Table $table, Column $column) + public function acceptColumn(Table $table, Column $column) : void { $this->addViolation( 'Table ' . $table->getName() . ' column ' . $column->getName(), @@ -90,35 +85,35 @@ public function acceptColumn(Table $table, Column $column) /** * {@inheritdoc} */ - public function acceptForeignKey(Table $localTable, ForeignKeyConstraint $fkConstraint) + public function acceptForeignKey(Table $localTable, ForeignKeyConstraint $fkConstraint) : void { } /** * {@inheritdoc} */ - public function acceptIndex(Table $table, Index $index) + public function acceptIndex(Table $table, Index $index) : void { } /** * {@inheritdoc} */ - public function acceptSchema(Schema $schema) + public function acceptSchema(Schema $schema) : void { } /** * {@inheritdoc} */ - public function acceptSequence(Sequence $sequence) + public function acceptSequence(Sequence $sequence) : void { } /** * {@inheritdoc} */ - public function acceptTable(Table $table) + public function acceptTable(Table $table) : void { $this->addViolation( 'Table ' . $table->getName(), diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/SQLAnywhereKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/SQLAnywhereKeywords.php index f7b6b0bd2a5..29c4f8477c9 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/SQLAnywhereKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/SQLAnywhereKeywords.php @@ -12,7 +12,7 @@ class SQLAnywhereKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'SQLAnywhere'; } @@ -22,7 +22,7 @@ public function getName() * * @link http://infocenter.sybase.com/help/topic/com.sybase.dbrfen10/pdf/dbrfen10.pdf?noframes=true */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ADD', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/SQLServer2012Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/SQLServer2012Keywords.php index df64901862a..218e1cd4ea6 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/SQLServer2012Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/SQLServer2012Keywords.php @@ -16,7 +16,7 @@ class SQLServer2012Keywords extends SQLServerKeywords /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'SQLServer2012'; } @@ -26,7 +26,7 @@ public function getName() * * @link http://msdn.microsoft.com/en-us/library/ms189822.aspx */ - protected function getKeywords() + protected function getKeywords() : array { return array_merge(parent::getKeywords(), [ 'SEMANTICKEYPHRASETABLE', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/SQLServerKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/SQLServerKeywords.php index b72e7342e3b..d30c22ed67c 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/SQLServerKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/SQLServerKeywords.php @@ -14,7 +14,7 @@ class SQLServerKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'SQLServer'; } @@ -24,7 +24,7 @@ public function getName() * * @link http://msdn.microsoft.com/en-us/library/aa238507%28v=sql.80%29.aspx */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ADD', diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/SQLiteKeywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/SQLiteKeywords.php index 22c92d72f11..6b44ac7bb87 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/SQLiteKeywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/SQLiteKeywords.php @@ -12,7 +12,7 @@ class SQLiteKeywords extends KeywordList /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'SQLite'; } @@ -20,7 +20,7 @@ public function getName() /** * {@inheritdoc} */ - protected function getKeywords() + protected function getKeywords() : array { return [ 'ABORT', diff --git a/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php b/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php index 27118c71988..57af4c20af1 100644 --- a/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php +++ b/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php @@ -16,7 +16,7 @@ class MySQL57Platform extends MySqlPlatform /** * {@inheritdoc} */ - public function hasNativeJsonType() + public function hasNativeJsonType() : bool { return true; } @@ -24,7 +24,7 @@ public function hasNativeJsonType() /** * {@inheritdoc} */ - public function getJsonTypeDeclarationSQL(array $field) + public function getJsonTypeDeclarationSQL(array $field) : string { return 'JSON'; } @@ -32,7 +32,7 @@ public function getJsonTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) : array { return []; } @@ -40,7 +40,7 @@ protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) /** * {@inheritdoc} */ - protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) + protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) : array { return []; } @@ -48,7 +48,7 @@ protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { return ['ALTER TABLE ' . $tableName . ' RENAME INDEX ' . $oldIndexName . ' TO ' . $index->getQuotedName($this)]; } @@ -56,7 +56,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) /** * {@inheritdoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\MySQL57Keywords::class; } @@ -64,7 +64,7 @@ protected function getReservedKeywordsClass() /** * {@inheritdoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { parent::initializeDoctrineTypeMappings(); diff --git a/lib/Doctrine/DBAL/Platforms/MySQL80Platform.php b/lib/Doctrine/DBAL/Platforms/MySQL80Platform.php index 7e07dc9dbb7..cdf8428628f 100644 --- a/lib/Doctrine/DBAL/Platforms/MySQL80Platform.php +++ b/lib/Doctrine/DBAL/Platforms/MySQL80Platform.php @@ -12,7 +12,7 @@ class MySQL80Platform extends MySQL57Platform /** * {@inheritdoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\MySQL80Keywords::class; } diff --git a/lib/Doctrine/DBAL/Platforms/MySqlPlatform.php b/lib/Doctrine/DBAL/Platforms/MySqlPlatform.php index 85f16d40fc0..ffefac2e69c 100644 --- a/lib/Doctrine/DBAL/Platforms/MySqlPlatform.php +++ b/lib/Doctrine/DBAL/Platforms/MySqlPlatform.php @@ -66,7 +66,7 @@ protected function doModifyLimitQuery(string $query, ?int $limit, int $offset) : /** * {@inheritDoc} */ - public function getIdentifierQuoteCharacter() + public function getIdentifierQuoteCharacter() : string { return '`'; } @@ -120,7 +120,7 @@ public function getDateDiffExpression(string $date1, string $date2) : string /** * {@inheritDoc} */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { return 'SHOW DATABASES'; } @@ -128,7 +128,7 @@ public function getListDatabasesSQL() /** * {@inheritDoc} */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { return 'SHOW INDEX FROM ' . $table; } @@ -139,7 +139,7 @@ public function getListTableConstraintsSQL($table) * Two approaches to listing the table indexes. The information_schema is * preferred, because it doesn't cause problems with SQL keywords such as "order" or "table". */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { if ($currentDatabase) { $currentDatabase = $this->quoteStringLiteral($currentDatabase); @@ -158,24 +158,18 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { - $database = $this->quoteStringLiteral($database); - - return 'SELECT * FROM information_schema.VIEWS WHERE TABLE_SCHEMA = ' . $database; + return 'SELECT * FROM information_schema.VIEWS WHERE TABLE_SCHEMA = ' . $this->quoteStringLiteral($database); } /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table, $database = null) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { $table = $this->quoteStringLiteral($table); - if ($database !== null) { - $database = $this->quoteStringLiteral($database); - } - $sql = 'SELECT DISTINCT k.`CONSTRAINT_NAME`, k.`COLUMN_NAME`, k.`REFERENCED_TABLE_NAME`, ' . 'k.`REFERENCED_COLUMN_NAME` /*!50116 , c.update_rule, c.delete_rule */ ' . 'FROM information_schema.key_column_usage k /*!50116 ' . @@ -183,7 +177,7 @@ public function getListTableForeignKeysSQL($table, $database = null) ' c.constraint_name = k.constraint_name AND ' . ' c.table_name = ' . $table . ' */ WHERE k.table_name = ' . $table; - $databaseNameSql = $database ?? 'DATABASE()'; + $databaseNameSql = $this->getDatabaseNameSql($database); $sql .= ' AND k.table_schema = ' . $databaseNameSql . ' /*!50116 AND c.constraint_schema = ' . $databaseNameSql . ' */'; $sql .= ' AND k.`REFERENCED_COLUMN_NAME` is not NULL'; @@ -194,7 +188,7 @@ public function getListTableForeignKeysSQL($table, $database = null) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -202,7 +196,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -210,7 +204,7 @@ public function getDropViewSQL($name) /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(255)') : ($length ? 'VARCHAR(' . $length . ')' : 'VARCHAR(255)'); @@ -219,7 +213,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? 'BINARY(' . ($length ?: 255) . ')' : 'VARBINARY(' . ($length ?: 255) . ')'; } @@ -233,7 +227,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) * * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { if (! empty($field['length']) && is_numeric($field['length'])) { $length = $field['length']; @@ -257,7 +251,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { if (isset($fieldDeclaration['version']) && $fieldDeclaration['version'] === true) { return 'TIMESTAMP'; @@ -269,7 +263,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -277,7 +271,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME'; } @@ -285,7 +279,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $field) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'TINYINT(1)'; } @@ -296,7 +290,7 @@ public function getBooleanTypeDeclarationSQL(array $field) * MySql prefers "autoincrement" identity columns since sequences can only * be emulated with a table. */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return true; } @@ -306,7 +300,7 @@ public function prefersIdentityColumns() * * MySql supports this through AUTO_INCREMENT columns. */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -314,7 +308,7 @@ public function supportsIdentityColumns() /** * {@inheritDoc} */ - public function supportsInlineColumnComments() + public function supportsInlineColumnComments() : bool { return true; } @@ -322,7 +316,7 @@ public function supportsInlineColumnComments() /** * {@inheritDoc} */ - public function supportsColumnCollation() + public function supportsColumnCollation() : bool { return true; } @@ -330,7 +324,7 @@ public function supportsColumnCollation() /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return "SHOW FULL TABLES WHERE Table_type = 'BASE TABLE'"; } @@ -338,21 +332,13 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { - $table = $this->quoteStringLiteral($table); - - if ($database) { - $database = $this->quoteStringLiteral($database); - } else { - $database = 'DATABASE()'; - } - return 'SELECT COLUMN_NAME AS Field, COLUMN_TYPE AS Type, IS_NULLABLE AS `Null`, ' . 'COLUMN_KEY AS `Key`, COLUMN_DEFAULT AS `Default`, EXTRA AS Extra, COLUMN_COMMENT AS Comment, ' . 'CHARACTER_SET_NAME AS CharacterSet, COLLATION_NAME AS Collation ' . - 'FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = ' . $database . ' AND TABLE_NAME = ' . $table . - ' ORDER BY ORDINAL_POSITION ASC'; + 'FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = ' . $this->getDatabaseNameSql($database) . ' ' . + 'AND TABLE_NAME = ' . $this->quoteStringLiteral($table) . ' ORDER BY ORDINAL_POSITION'; } public function getListTableMetadataSQL(string $table, ?string $database = null) : string @@ -372,23 +358,23 @@ public function getListTableMetadataSQL(string $table, ?string $database = null) /** * {@inheritDoc} */ - public function getCreateDatabaseSQL($name) + public function getCreateDatabaseSQL(string $database) : string { - return 'CREATE DATABASE ' . $name; + return 'CREATE DATABASE ' . $database; } /** * {@inheritDoc} */ - public function getDropDatabaseSQL($name) + public function getDropDatabaseSQL(string $database) : string { - return 'DROP DATABASE ' . $name; + return 'DROP DATABASE ' . $database; } /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $queryFields = $this->getColumnDeclarationListSQL($columns); @@ -441,7 +427,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options /** * {@inheritdoc} */ - public function getDefaultValueDeclarationSQL($field) + public function getDefaultValueDeclarationSQL(array $field) : string { // Unset the default value if the given field definition does not allow default values. if ($field['type'] instanceof TextType || $field['type'] instanceof BlobType) { @@ -455,10 +441,8 @@ public function getDefaultValueDeclarationSQL($field) * Build SQL for table options * * @param mixed[] $options - * - * @return string */ - private function buildTableOptions(array $options) + private function buildTableOptions(array $options) : string { if (isset($options['table_options'])) { return $options['table_options']; @@ -509,10 +493,8 @@ private function buildTableOptions(array $options) * Build SQL for partition options. * * @param mixed[] $options - * - * @return string */ - private function buildPartitionOptions(array $options) + private function buildPartitionOptions(array $options) : string { return isset($options['partition_options']) ? ' ' . $options['partition_options'] @@ -522,7 +504,7 @@ private function buildPartitionOptions(array $options) /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $columnSql = []; $queryParts = []; @@ -620,7 +602,7 @@ public function getAlterTableSQL(TableDiff $diff) /** * {@inheritDoc} */ - protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $table = $diff->getName($this)->getQuotedName($this); @@ -681,7 +663,7 @@ protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) /** * @return string[] */ - private function getPreAlterTableAlterPrimaryKeySQL(TableDiff $diff, Index $index) + private function getPreAlterTableAlterPrimaryKeySQL(TableDiff $diff, Index $index) : array { $sql = []; @@ -699,7 +681,7 @@ private function getPreAlterTableAlterPrimaryKeySQL(TableDiff $diff, Index $inde $column = $diff->fromTable->getColumn($columnName); - if ($column->getAutoincrement() !== true) { + if (! $column->getAutoincrement()) { continue; } @@ -720,7 +702,7 @@ private function getPreAlterTableAlterPrimaryKeySQL(TableDiff $diff, Index $inde * * @return string[] */ - private function getPreAlterTableAlterIndexForeignKeySQL(TableDiff $diff) + private function getPreAlterTableAlterIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $table = $diff->getName($this)->getQuotedName($this); @@ -760,7 +742,7 @@ private function getPreAlterTableAlterIndexForeignKeySQL(TableDiff $diff) * * @return string[] */ - protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $tableName = $diff->getName($this)->getQuotedName($this); @@ -786,7 +768,7 @@ protected function getPreAlterTableRenameIndexForeignKeySQL(TableDiff $diff) * * @return ForeignKeyConstraint[] */ - private function getRemainingForeignKeyConstraintsRequiringRenamedIndexes(TableDiff $diff) + private function getRemainingForeignKeyConstraintsRequiringRenamedIndexes(TableDiff $diff) : array { if (empty($diff->renamedIndexes) || ! $diff->fromTable instanceof Table) { return []; @@ -815,7 +797,7 @@ private function getRemainingForeignKeyConstraintsRequiringRenamedIndexes(TableD /** * {@inheritdoc} */ - protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) : array { return array_merge( parent::getPostAlterTableIndexForeignKeySQL($diff), @@ -828,7 +810,7 @@ protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) * * @return string[] */ - protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) + protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) : array { $sql = []; $newName = $diff->getNewName(); @@ -853,7 +835,7 @@ protected function getPostAlterTableRenameIndexForeignKeySQL(TableDiff $diff) /** * {@inheritDoc} */ - protected function getCreateIndexSQLFlags(Index $index) + protected function getCreateIndexSQLFlags(Index $index) : string { $type = ''; if ($index->isUnique()) { @@ -870,39 +852,39 @@ protected function getCreateIndexSQLFlags(Index $index) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $field) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { - return 'INT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'INT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $field) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { - return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $field) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { - return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritdoc} */ - public function getFloatDeclarationSQL(array $field) + public function getFloatDeclarationSQL(array $fieldDeclaration) : string { - return 'DOUBLE PRECISION' . $this->getUnsignedDeclaration($field); + return 'DOUBLE PRECISION' . $this->getUnsignedDeclaration($fieldDeclaration); } /** * {@inheritdoc} */ - public function getDecimalTypeDeclarationSQL(array $columnDef) + public function getDecimalTypeDeclarationSQL(array $columnDef) : string { return parent::getDecimalTypeDeclarationSQL($columnDef) . $this->getUnsignedDeclaration($columnDef); } @@ -911,10 +893,8 @@ public function getDecimalTypeDeclarationSQL(array $columnDef) * Get unsigned declaration for a column. * * @param mixed[] $columnDef - * - * @return string */ - private function getUnsignedDeclaration(array $columnDef) + private function getUnsignedDeclaration(array $columnDef) : string { return ! empty($columnDef['unsigned']) ? ' UNSIGNED' : ''; } @@ -922,7 +902,7 @@ private function getUnsignedDeclaration(array $columnDef) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { $autoinc = ''; if (! empty($columnDef['autoincrement'])) { @@ -935,7 +915,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getColumnCharsetDeclarationSQL($charset) + public function getColumnCharsetDeclarationSQL(string $charset) : string { return 'CHARACTER SET ' . $charset; } @@ -943,7 +923,7 @@ public function getColumnCharsetDeclarationSQL($charset) /** * {@inheritDoc} */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $query = ''; if ($foreignKey->hasOption('match')) { @@ -957,7 +937,7 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey /** * {@inheritDoc} */ - public function getDropIndexSQL($index, $table = null) + public function getDropIndexSQL($index, $table = null) : string { if ($index instanceof Index) { $indexName = $index->getQuotedName($this); @@ -982,12 +962,7 @@ public function getDropIndexSQL($index, $table = null) return 'DROP INDEX ' . $indexName . ' ON ' . $table; } - /** - * @param string $table - * - * @return string - */ - protected function getDropPrimaryKeySQL($table) + protected function getDropPrimaryKeySQL(string $table) : string { return 'ALTER TABLE ' . $table . ' DROP PRIMARY KEY'; } @@ -995,7 +970,7 @@ protected function getDropPrimaryKeySQL($table) /** * {@inheritDoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'SET SESSION TRANSACTION ISOLATION LEVEL ' . $this->_getTransactionIsolationLevelSQL($level); } @@ -1003,7 +978,7 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'mysql'; } @@ -1011,7 +986,7 @@ public function getName() /** * {@inheritDoc} */ - public function getReadLockSQL() + public function getReadLockSQL() : string { return 'LOCK IN SHARE MODE'; } @@ -1019,7 +994,7 @@ public function getReadLockSQL() /** * {@inheritDoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', @@ -1058,7 +1033,7 @@ protected function initializeDoctrineTypeMappings() /** * {@inheritDoc} */ - public function getVarcharMaxLength() + public function getVarcharMaxLength() : int { return 65535; } @@ -1066,7 +1041,7 @@ public function getVarcharMaxLength() /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 65535; } @@ -1074,7 +1049,7 @@ public function getBinaryMaxLength() /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\MySQLKeywords::class; } @@ -1085,7 +1060,7 @@ protected function getReservedKeywordsClass() * MySQL commits a transaction implicitly when DROP TABLE is executed, however not * if DROP TEMPORARY TABLE is executed. */ - public function getDropTemporaryTableSQL($table) + public function getDropTemporaryTableSQL($table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -1105,7 +1080,7 @@ public function getDropTemporaryTableSQL($table) * * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { if (! empty($field['length']) && is_numeric($field['length'])) { $length = $field['length']; @@ -1129,7 +1104,7 @@ public function getBlobTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - public function quoteStringLiteral($str) + public function quoteStringLiteral(string $str) : string { $str = str_replace('\\', '\\\\', $str); // MySQL requires backslashes to be escaped aswell. @@ -1139,7 +1114,7 @@ public function quoteStringLiteral($str) /** * {@inheritdoc} */ - public function getDefaultTransactionIsolationLevel() + public function getDefaultTransactionIsolationLevel() : int { return TransactionIsolationLevel::REPEATABLE_READ; } @@ -1151,4 +1126,18 @@ public function supportsColumnLengthIndexes() : bool { return true; } + + /** + * Returns an SQL expression representing the given database name or current database name + * + * @param string|null $database Database name + */ + private function getDatabaseNameSql(?string $database) : string + { + if ($database === null) { + return 'DATABASE()'; + } + + return $this->quoteStringLiteral($database); + } } diff --git a/lib/Doctrine/DBAL/Platforms/OraclePlatform.php b/lib/Doctrine/DBAL/Platforms/OraclePlatform.php index 33a543d2004..dd246fe1eb3 100644 --- a/lib/Doctrine/DBAL/Platforms/OraclePlatform.php +++ b/lib/Doctrine/DBAL/Platforms/OraclePlatform.php @@ -35,11 +35,9 @@ class OraclePlatform extends AbstractPlatform * * @link http://docs.oracle.com/cd/B19306_01/server.102/b14200/sql_elements008.htm * - * @param string $identifier - * * @throws DBALException */ - public static function assertValidIdentifier($identifier) + public static function assertValidIdentifier(string $identifier) : void { if (! preg_match('(^(([a-zA-Z]{1}[a-zA-Z0-9_$#]{0,})|("[^"]+"))$)', $identifier)) { throw new DBALException('Invalid Oracle identifier.'); @@ -61,7 +59,7 @@ public function getSubstringExpression(string $string, string $start, ?string $l /** * {@inheritDoc} */ - public function getNowExpression($type = 'timestamp') : string + public function getNowExpression(string $type = 'timestamp') : string { switch ($type) { case 'date': @@ -163,7 +161,7 @@ public function getBitOrComparisonExpression(string $value1, string $value2) : s * Therefore we can use MINVALUE to be able to get a hint what START WITH was for later introspection * in {@see listSequences()} */ - public function getCreateSequenceSQL(Sequence $sequence) + public function getCreateSequenceSQL(Sequence $sequence) : string { return 'CREATE SEQUENCE ' . $sequence->getQuotedName($this) . ' START WITH ' . $sequence->getInitialValue() . @@ -175,7 +173,7 @@ public function getCreateSequenceSQL(Sequence $sequence) /** * {@inheritDoc} */ - public function getAlterSequenceSQL(Sequence $sequence) + public function getAlterSequenceSQL(Sequence $sequence) : string { return 'ALTER SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize() @@ -184,10 +182,8 @@ public function getAlterSequenceSQL(Sequence $sequence) /** * Cache definition for sequences - * - * @return string */ - private function getSequenceCacheSQL(Sequence $sequence) + private function getSequenceCacheSQL(Sequence $sequence) : string { if ($sequence->getCache() === 0) { return ' NOCACHE'; @@ -207,7 +203,7 @@ private function getSequenceCacheSQL(Sequence $sequence) /** * {@inheritDoc} */ - public function getSequenceNextValSQL($sequenceName) + public function getSequenceNextValSQL(string $sequenceName) : string { return 'SELECT ' . $sequenceName . '.nextval FROM DUAL'; } @@ -215,7 +211,7 @@ public function getSequenceNextValSQL($sequenceName) /** * {@inheritDoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'SET TRANSACTION ISOLATION LEVEL ' . $this->_getTransactionIsolationLevelSQL($level); } @@ -223,7 +219,7 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritDoc} */ - protected function _getTransactionIsolationLevelSQL($level) + protected function _getTransactionIsolationLevelSQL(int $level) : string { switch ($level) { case TransactionIsolationLevel::READ_UNCOMMITTED: @@ -241,7 +237,7 @@ protected function _getTransactionIsolationLevelSQL($level) /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $field) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'NUMBER(1)'; } @@ -249,7 +245,7 @@ public function getBooleanTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $field) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { return 'NUMBER(10)'; } @@ -257,7 +253,7 @@ public function getIntegerTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $field) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { return 'NUMBER(20)'; } @@ -265,7 +261,7 @@ public function getBigIntTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $field) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { return 'NUMBER(5)'; } @@ -273,7 +269,7 @@ public function getSmallIntTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIMESTAMP(0)'; } @@ -281,7 +277,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIMESTAMP(0) WITH TIME ZONE'; } @@ -289,7 +285,7 @@ public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -297,7 +293,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -305,7 +301,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { return ''; } @@ -313,7 +309,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(2000)') : ($length ? 'VARCHAR2(' . $length . ')' : 'VARCHAR2(4000)'); @@ -322,7 +318,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return 'RAW(' . ($length ?: $this->getBinaryMaxLength()) . ')'; } @@ -330,7 +326,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 2000; } @@ -338,7 +334,7 @@ public function getBinaryMaxLength() /** * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { return 'CLOB'; } @@ -346,7 +342,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { return 'SELECT username FROM all_users'; } @@ -354,19 +350,18 @@ public function getListDatabasesSQL() /** * {@inheritDoc} */ - public function getListSequencesSQL($database) + public function getListSequencesSQL(string $database) : string { - $database = $this->normalizeIdentifier($database); - $database = $this->quoteStringLiteral($database->getName()); - - return 'SELECT sequence_name, min_value, increment_by FROM sys.all_sequences ' . - 'WHERE SEQUENCE_OWNER = ' . $database; + return 'SELECT SEQUENCE_NAME, MIN_VALUE, INCREMENT_BY FROM SYS.ALL_SEQUENCES WHERE SEQUENCE_OWNER = ' + . $this->quoteStringLiteral( + $this->normalizeIdentifier($database)->getName() + ); } /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $indexes = $options['indexes'] ?? []; $options['indexes'] = []; @@ -399,7 +394,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options * * @link http://ezcomponents.org/docs/api/trunk/DatabaseSchema/ezcDbSchemaOracleReader.html */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { $table = $this->normalizeIdentifier($table); $table = $this->quoteStringLiteral($table->getName()); @@ -436,7 +431,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return 'SELECT * FROM sys.user_tables'; } @@ -444,7 +439,7 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return 'SELECT view_name, text FROM sys.user_views'; } @@ -452,7 +447,7 @@ public function getListViewsSQL($database) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -460,19 +455,15 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } /** - * @param string $name - * @param string $table - * @param int $start - * * @return string[] */ - public function getCreateAutoincrementSql($name, $table, $start = 1) + public function getCreateAutoincrementSql(string $name, string $table, int $start = 1) : array { $tableIdentifier = $this->normalizeIdentifier($table); $quotedTableName = $tableIdentifier->getQuotedName($this); @@ -536,7 +527,7 @@ public function getCreateAutoincrementSql($name, $table, $start = 1) * * @return string[] */ - public function getDropAutoincrementSql($table) + public function getDropAutoincrementSql(string $table) : array { $table = $this->normalizeIdentifier($table); $autoincrementIdentifierName = $this->getAutoincrementIdentifierName($table); @@ -562,7 +553,7 @@ public function getDropAutoincrementSql($table) * * @return Identifier The normalized identifier. */ - private function normalizeIdentifier($name) + private function normalizeIdentifier(string $name) : Identifier { $identifier = new Identifier($name); @@ -576,10 +567,8 @@ private function normalizeIdentifier($name) * if the given table name is quoted by intention. * * @param Identifier $table The table identifier to return the autoincrement primary key identifier name for. - * - * @return string */ - private function getAutoincrementIdentifierName(Identifier $table) + private function getAutoincrementIdentifierName(Identifier $table) : string { $identifierName = $table->getName() . '_AI_PK'; @@ -591,7 +580,7 @@ private function getAutoincrementIdentifierName(Identifier $table) /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { $table = $this->normalizeIdentifier($table); $table = $this->quoteStringLiteral($table->getName()); @@ -623,7 +612,7 @@ public function getListTableForeignKeysSQL($table) /** * {@inheritDoc} */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { $table = $this->normalizeIdentifier($table); $table = $this->quoteStringLiteral($table->getName()); @@ -634,7 +623,7 @@ public function getListTableConstraintsSQL($table) /** * {@inheritDoc} */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { $table = $this->normalizeIdentifier($table); $table = $this->quoteStringLiteral($table->getName()); @@ -678,7 +667,7 @@ public function getListTableColumnsSQL($table, $database = null) /** * {@inheritDoc} */ - public function getDropSequenceSQL($sequence) + public function getDropSequenceSQL($sequence) : string { if ($sequence instanceof Sequence) { $sequence = $sequence->getQuotedName($this); @@ -690,7 +679,7 @@ public function getDropSequenceSQL($sequence) /** * {@inheritDoc} */ - public function getDropForeignKeySQL($foreignKey, $table) + public function getDropForeignKeySQL($foreignKey, $table) : string { if (! $foreignKey instanceof ForeignKeyConstraint) { $foreignKey = new Identifier($foreignKey); @@ -709,7 +698,7 @@ public function getDropForeignKeySQL($foreignKey, $table) /** * {@inheritdoc} */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $referentialAction = null; @@ -723,7 +712,7 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey /** * {@inheritdoc} */ - public function getForeignKeyReferentialActionSQL($action) + public function getForeignKeyReferentialActionSQL(string $action) : string { $action = strtoupper($action); @@ -747,7 +736,7 @@ public function getForeignKeyReferentialActionSQL($action) /** * {@inheritDoc} */ - public function getDropDatabaseSQL($database) + public function getDropDatabaseSQL(string $database) : string { return 'DROP USER ' . $database . ' CASCADE'; } @@ -755,7 +744,7 @@ public function getDropDatabaseSQL($database) /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $sql = []; $commentsSQL = []; @@ -886,7 +875,7 @@ public function getAlterTableSQL(TableDiff $diff) /** * {@inheritdoc} */ - public function getColumnDeclarationSQL($name, array $field) + public function getColumnDeclarationSQL(string $name, array $field) : string { if (isset($field['columnDefinition'])) { $columnDef = $this->getCustomTypeDeclarationSQL($field); @@ -915,7 +904,7 @@ public function getColumnDeclarationSQL($name, array $field) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { if (strpos($tableName, '.') !== false) { [$schema] = explode('.', $tableName); @@ -928,7 +917,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) /** * {@inheritDoc} */ - public function prefersSequences() + public function prefersSequences() : bool { return true; } @@ -936,7 +925,7 @@ public function prefersSequences() /** * {@inheritdoc} */ - public function usesSequenceEmulatedIdentityColumns() + public function usesSequenceEmulatedIdentityColumns() : bool { return true; } @@ -944,7 +933,7 @@ public function usesSequenceEmulatedIdentityColumns() /** * {@inheritdoc} */ - public function getIdentitySequenceName($tableName, $columnName) + public function getIdentitySequenceName(string $tableName, string $columnName) : string { $table = new Identifier($tableName); @@ -963,7 +952,7 @@ public function getIdentitySequenceName($tableName, $columnName) /** * {@inheritDoc} */ - public function supportsCommentOnStatement() + public function supportsCommentOnStatement() : bool { return true; } @@ -971,7 +960,7 @@ public function supportsCommentOnStatement() /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'oracle'; } @@ -1015,7 +1004,7 @@ protected function doModifyLimitQuery(string $query, ?int $limit, int $offset) : * * Oracle returns all column names in SQL result sets in uppercase. */ - public function getSQLResultCasing($column) + public function getSQLResultCasing(string $column) : string { return strtoupper($column); } @@ -1023,7 +1012,7 @@ public function getSQLResultCasing($column) /** * {@inheritDoc} */ - public function getCreateTemporaryTableSnippetSQL() + public function getCreateTemporaryTableSnippetSQL() : string { return 'CREATE GLOBAL TEMPORARY TABLE'; } @@ -1031,7 +1020,7 @@ public function getCreateTemporaryTableSnippetSQL() /** * {@inheritDoc} */ - public function getDateTimeTzFormatString() + public function getDateTimeTzFormatString() : string { return 'Y-m-d H:i:sP'; } @@ -1039,7 +1028,7 @@ public function getDateTimeTzFormatString() /** * {@inheritDoc} */ - public function getDateFormatString() + public function getDateFormatString() : string { return 'Y-m-d 00:00:00'; } @@ -1047,7 +1036,7 @@ public function getDateFormatString() /** * {@inheritDoc} */ - public function getTimeFormatString() + public function getTimeFormatString() : string { return '1900-01-01 H:i:s'; } @@ -1055,7 +1044,7 @@ public function getTimeFormatString() /** * {@inheritDoc} */ - public function fixSchemaElementName($schemaElementName) + public function fixSchemaElementName(string $schemaElementName) : string { if (strlen($schemaElementName) > 30) { // Trim it @@ -1068,7 +1057,7 @@ public function fixSchemaElementName($schemaElementName) /** * {@inheritDoc} */ - public function getMaxIdentifierLength() + public function getMaxIdentifierLength() : int { return 30; } @@ -1076,7 +1065,7 @@ public function getMaxIdentifierLength() /** * {@inheritDoc} */ - public function supportsSequences() + public function supportsSequences() : bool { return true; } @@ -1084,7 +1073,7 @@ public function supportsSequences() /** * {@inheritDoc} */ - public function supportsForeignKeyOnUpdate() + public function supportsForeignKeyOnUpdate() : bool { return false; } @@ -1092,7 +1081,7 @@ public function supportsForeignKeyOnUpdate() /** * {@inheritDoc} */ - public function supportsReleaseSavepoints() + public function supportsReleaseSavepoints() : bool { return false; } @@ -1100,7 +1089,7 @@ public function supportsReleaseSavepoints() /** * {@inheritDoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); @@ -1118,7 +1107,7 @@ public function getDummySelectSQL(string $expression = '1') : string /** * {@inheritDoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'binary_double' => 'float', @@ -1150,7 +1139,7 @@ protected function initializeDoctrineTypeMappings() /** * {@inheritDoc} */ - public function releaseSavePoint($savepoint) + public function releaseSavePoint(string $savepoint) : string { return ''; } @@ -1158,7 +1147,7 @@ public function releaseSavePoint($savepoint) /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\OracleKeywords::class; } @@ -1166,7 +1155,7 @@ protected function getReservedKeywordsClass() /** * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { return 'BLOB'; } diff --git a/lib/Doctrine/DBAL/Platforms/PostgreSQL100Platform.php b/lib/Doctrine/DBAL/Platforms/PostgreSQL100Platform.php index cfb079f94dd..9704a6c3b41 100644 --- a/lib/Doctrine/DBAL/Platforms/PostgreSQL100Platform.php +++ b/lib/Doctrine/DBAL/Platforms/PostgreSQL100Platform.php @@ -19,7 +19,7 @@ protected function getReservedKeywordsClass() : string return PostgreSQL100Keywords::class; } - public function getListSequencesSQL($database) : string + public function getListSequencesSQL(string $database) : string { return 'SELECT sequence_name AS relname, sequence_schema AS schemaname, diff --git a/lib/Doctrine/DBAL/Platforms/PostgreSQL94Platform.php b/lib/Doctrine/DBAL/Platforms/PostgreSQL94Platform.php index 87d903b7feb..59841153a5e 100644 --- a/lib/Doctrine/DBAL/Platforms/PostgreSQL94Platform.php +++ b/lib/Doctrine/DBAL/Platforms/PostgreSQL94Platform.php @@ -13,8 +13,10 @@ class PostgreSQL94Platform extends PostgreSqlPlatform { /** * {@inheritdoc} + * + * @return string */ - public function getJsonTypeDeclarationSQL(array $field) + public function getJsonTypeDeclarationSQL(array $field) : string { if (! empty($field['jsonb'])) { return 'JSONB'; @@ -26,7 +28,7 @@ public function getJsonTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\PostgreSQL94Keywords::class; } @@ -34,7 +36,7 @@ protected function getReservedKeywordsClass() /** * {@inheritdoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { parent::initializeDoctrineTypeMappings(); diff --git a/lib/Doctrine/DBAL/Platforms/PostgreSqlPlatform.php b/lib/Doctrine/DBAL/Platforms/PostgreSqlPlatform.php index 8f20096367c..d86a302a3ab 100644 --- a/lib/Doctrine/DBAL/Platforms/PostgreSqlPlatform.php +++ b/lib/Doctrine/DBAL/Platforms/PostgreSqlPlatform.php @@ -4,7 +4,6 @@ namespace Doctrine\DBAL\Platforms; -use Doctrine\DBAL\Schema\Column; use Doctrine\DBAL\Schema\ColumnDiff; use Doctrine\DBAL\Schema\ForeignKeyConstraint; use Doctrine\DBAL\Schema\Identifier; @@ -69,12 +68,10 @@ class PostgreSqlPlatform extends AbstractPlatform * with regard to how booleans have to be handled. * * Enables use of 'true'/'false' or otherwise 1 and 0 instead. - * - * @param bool $flag */ - public function setUseBooleanTrueFalseStrings($flag) + public function setUseBooleanTrueFalseStrings(bool $flag) : void { - $this->useBooleanTrueFalseStrings = (bool) $flag; + $this->useBooleanTrueFalseStrings = $flag; } /** @@ -131,7 +128,7 @@ public function getDateDiffExpression(string $date1, string $date2) : string /** * {@inheritDoc} */ - public function supportsSequences() + public function supportsSequences() : bool { return true; } @@ -139,7 +136,7 @@ public function supportsSequences() /** * {@inheritDoc} */ - public function supportsSchemas() + public function supportsSchemas() : bool { return true; } @@ -147,7 +144,7 @@ public function supportsSchemas() /** * {@inheritdoc} */ - public function getDefaultSchemaName() + public function getDefaultSchemaName() : string { return 'public'; } @@ -155,7 +152,7 @@ public function getDefaultSchemaName() /** * {@inheritDoc} */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -163,7 +160,7 @@ public function supportsIdentityColumns() /** * {@inheritdoc} */ - public function supportsPartialIndexes() + public function supportsPartialIndexes() : bool { return true; } @@ -171,7 +168,7 @@ public function supportsPartialIndexes() /** * {@inheritdoc} */ - public function usesSequenceEmulatedIdentityColumns() + public function usesSequenceEmulatedIdentityColumns() : bool { return true; } @@ -179,7 +176,7 @@ public function usesSequenceEmulatedIdentityColumns() /** * {@inheritdoc} */ - public function getIdentitySequenceName($tableName, $columnName) + public function getIdentitySequenceName(string $tableName, string $columnName) : string { return $tableName . '_' . $columnName . '_seq'; } @@ -187,7 +184,7 @@ public function getIdentitySequenceName($tableName, $columnName) /** * {@inheritDoc} */ - public function supportsCommentOnStatement() + public function supportsCommentOnStatement() : bool { return true; } @@ -195,7 +192,7 @@ public function supportsCommentOnStatement() /** * {@inheritDoc} */ - public function prefersSequences() + public function prefersSequences() : bool { return true; } @@ -203,7 +200,7 @@ public function prefersSequences() /** * {@inheritDoc} */ - public function hasNativeGuidType() + public function hasNativeGuidType() : bool { return true; } @@ -211,7 +208,7 @@ public function hasNativeGuidType() /** * {@inheritDoc} */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { return 'SELECT datname FROM pg_database'; } @@ -219,7 +216,7 @@ public function getListDatabasesSQL() /** * {@inheritDoc} */ - public function getListNamespacesSQL() + public function getListNamespacesSQL() : string { return "SELECT schema_name AS nspname FROM information_schema.schemata @@ -230,7 +227,7 @@ public function getListNamespacesSQL() /** * {@inheritDoc} */ - public function getListSequencesSQL($database) + public function getListSequencesSQL(string $database) : string { return "SELECT sequence_name AS relname, sequence_schema AS schemaname @@ -242,7 +239,7 @@ public function getListSequencesSQL($database) /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return "SELECT quote_ident(table_name) AS table_name, table_schema AS schema_name @@ -257,7 +254,7 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return 'SELECT quote_ident(table_name) AS viewname, table_schema AS schemaname, @@ -269,7 +266,7 @@ public function getListViewsSQL($database) /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table, $database = null) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { return 'SELECT quote_ident(r.conname) as conname, pg_catalog.pg_get_constraintdef(r.oid, true) as condef FROM pg_catalog.pg_constraint r @@ -285,7 +282,7 @@ public function getListTableForeignKeysSQL($table, $database = null) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -293,7 +290,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -301,7 +298,7 @@ public function getDropViewSQL($name) /** * {@inheritDoc} */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { $table = new Identifier($table); $table = $this->quoteStringLiteral($table->getName()); @@ -330,7 +327,7 @@ public function getListTableConstraintsSQL($table) * * @link http://ezcomponents.org/docs/api/trunk/DatabaseSchema/ezcDbSchemaPgsqlReader.html */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { return 'SELECT quote_ident(relname) as relname, pg_index.indisunique, pg_index.indisprimary, pg_index.indkey, pg_index.indrelid, @@ -343,14 +340,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) ) AND pg_index.indexrelid = oid'; } - /** - * @param string $table - * @param string $classAlias - * @param string $namespaceAlias - * - * @return string - */ - private function getTableWhereClause($table, $classAlias = 'c', $namespaceAlias = 'n') + private function getTableWhereClause(string $table, string $classAlias = 'c', string $namespaceAlias = 'n') : string { $whereClause = $namespaceAlias . ".nspname NOT IN ('pg_catalog', 'information_schema', 'pg_toast') AND "; if (strpos($table, '.') !== false) { @@ -375,7 +365,7 @@ private function getTableWhereClause($table, $classAlias = 'c', $namespaceAlias /** * {@inheritDoc} */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { return "SELECT a.attnum, @@ -413,9 +403,9 @@ public function getListTableColumnsSQL($table, $database = null) /** * {@inheritDoc} */ - public function getCreateDatabaseSQL($name) + public function getCreateDatabaseSQL(string $database) : string { - return 'CREATE DATABASE ' . $name; + return 'CREATE DATABASE ' . $database; } /** @@ -424,10 +414,8 @@ public function getCreateDatabaseSQL($name) * This is useful to force DROP DATABASE operations which could fail because of active connections. * * @param string $database The name of the database to disallow new connections for. - * - * @return string */ - public function getDisallowDatabaseConnectionsSQL($database) + public function getDisallowDatabaseConnectionsSQL(string $database) : string { return "UPDATE pg_database SET datallowconn = 'false' WHERE datname = " . $this->quoteStringLiteral($database); } @@ -438,10 +426,8 @@ public function getDisallowDatabaseConnectionsSQL($database) * This is useful to force DROP DATABASE operations which could fail because of active connections. * * @param string $database The name of the database to close currently active connections for. - * - * @return string */ - public function getCloseActiveDatabaseConnectionsSQL($database) + public function getCloseActiveDatabaseConnectionsSQL(string $database) : string { return 'SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE datname = ' . $this->quoteStringLiteral($database); @@ -450,7 +436,7 @@ public function getCloseActiveDatabaseConnectionsSQL($database) /** * {@inheritDoc} */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $query = ''; @@ -478,7 +464,7 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $sql = []; $commentsSQL = []; @@ -637,7 +623,7 @@ public function getAlterTableSQL(TableDiff $diff) * * @return bool True if the given column diff is an unchanged binary type column, false otherwise. */ - private function isUnchangedBinaryColumn(ColumnDiff $columnDiff) + private function isUnchangedBinaryColumn(ColumnDiff $columnDiff) : bool { $columnType = $columnDiff->column->getType(); @@ -645,9 +631,9 @@ private function isUnchangedBinaryColumn(ColumnDiff $columnDiff) return false; } - $fromColumn = $columnDiff->fromColumn instanceof Column ? $columnDiff->fromColumn : null; + $fromColumn = $columnDiff->fromColumn; - if ($fromColumn) { + if ($fromColumn !== null) { $fromColumnType = $fromColumn->getType(); if (! $fromColumnType instanceof BinaryType && ! $fromColumnType instanceof BlobType) { @@ -667,7 +653,7 @@ private function isUnchangedBinaryColumn(ColumnDiff $columnDiff) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { if (strpos($tableName, '.') !== false) { [$schema] = explode('.', $tableName); @@ -680,7 +666,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) /** * {@inheritdoc} */ - public function getCommentOnColumnSQL($tableName, $columnName, $comment) + public function getCommentOnColumnSQL(string $tableName, string $columnName, ?string $comment) : string { $tableName = new Identifier($tableName); $columnName = new Identifier($columnName); @@ -697,7 +683,7 @@ public function getCommentOnColumnSQL($tableName, $columnName, $comment) /** * {@inheritDoc} */ - public function getCreateSequenceSQL(Sequence $sequence) + public function getCreateSequenceSQL(Sequence $sequence) : string { return 'CREATE SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize() . @@ -709,7 +695,7 @@ public function getCreateSequenceSQL(Sequence $sequence) /** * {@inheritDoc} */ - public function getAlterSequenceSQL(Sequence $sequence) + public function getAlterSequenceSQL(Sequence $sequence) : string { return 'ALTER SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize() . @@ -718,10 +704,8 @@ public function getAlterSequenceSQL(Sequence $sequence) /** * Cache definition for sequences - * - * @return string */ - private function getSequenceCacheSQL(Sequence $sequence) + private function getSequenceCacheSQL(Sequence $sequence) : string { if ($sequence->getCache() > 1) { return ' CACHE ' . $sequence->getCache(); @@ -733,7 +717,7 @@ private function getSequenceCacheSQL(Sequence $sequence) /** * {@inheritDoc} */ - public function getDropSequenceSQL($sequence) + public function getDropSequenceSQL($sequence) : string { if ($sequence instanceof Sequence) { $sequence = $sequence->getQuotedName($this); @@ -745,7 +729,7 @@ public function getDropSequenceSQL($sequence) /** * {@inheritDoc} */ - public function getCreateSchemaSQL($schemaName) + public function getCreateSchemaSQL(string $schemaName) : string { return 'CREATE SCHEMA ' . $schemaName; } @@ -753,7 +737,7 @@ public function getCreateSchemaSQL($schemaName) /** * {@inheritDoc} */ - public function getDropForeignKeySQL($foreignKey, $table) + public function getDropForeignKeySQL($foreignKey, $table) : string { return $this->getDropConstraintSQL($foreignKey, $table); } @@ -761,7 +745,7 @@ public function getDropForeignKeySQL($foreignKey, $table) /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $queryFields = $this->getColumnDeclarationListSQL($columns); @@ -803,7 +787,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options * * @throws UnexpectedValueException */ - private function convertSingleBooleanValue($value, $callback) + private function convertSingleBooleanValue($value, callable $callback) { if ($value === null) { return $callback(null); @@ -846,7 +830,7 @@ private function convertSingleBooleanValue($value, $callback) * * @return mixed */ - private function doConvertBooleans($item, $callback) + private function doConvertBooleans($item, callable $callback) { if (is_array($item)) { foreach ($item as $key => $value) { @@ -872,7 +856,7 @@ public function convertBooleans($item) return $this->doConvertBooleans( $item, - static function ($boolean) { + static function ($boolean) : string { if ($boolean === null) { return 'NULL'; } @@ -893,7 +877,7 @@ public function convertBooleansToDatabaseValue($item) return $this->doConvertBooleans( $item, - static function ($boolean) { + static function ($boolean) : ?int { return $boolean === null ? null : (int) $boolean; } ); @@ -902,7 +886,7 @@ static function ($boolean) { /** * {@inheritDoc} */ - public function convertFromBoolean($item) + public function convertFromBoolean($item) : ?bool { if (in_array($item, $this->booleanLiterals['false'], true)) { return false; @@ -914,7 +898,7 @@ public function convertFromBoolean($item) /** * {@inheritDoc} */ - public function getSequenceNextValSQL($sequenceName) + public function getSequenceNextValSQL(string $sequenceName) : string { return "SELECT NEXTVAL('" . $sequenceName . "')"; } @@ -922,7 +906,7 @@ public function getSequenceNextValSQL($sequenceName) /** * {@inheritDoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'SET SESSION CHARACTERISTICS AS TRANSACTION ISOLATION LEVEL ' . $this->_getTransactionIsolationLevelSQL($level); @@ -931,7 +915,7 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $field) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'BOOLEAN'; } @@ -939,9 +923,9 @@ public function getBooleanTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $field) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { - if (! empty($field['autoincrement'])) { + if (! empty($columnDef['autoincrement'])) { return 'SERIAL'; } @@ -951,9 +935,9 @@ public function getIntegerTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $field) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { - if (! empty($field['autoincrement'])) { + if (! empty($columnDef['autoincrement'])) { return 'BIGSERIAL'; } @@ -963,9 +947,9 @@ public function getBigIntTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $field) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { - if (! empty($field['autoincrement'])) { + if (! empty($columnDef['autoincrement'])) { return 'SMALLSERIAL'; } @@ -975,7 +959,7 @@ public function getSmallIntTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getGuidTypeDeclarationSQL(array $field) + public function getGuidTypeDeclarationSQL(array $field) : string { return 'UUID'; } @@ -983,7 +967,7 @@ public function getGuidTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIMESTAMP(0) WITHOUT TIME ZONE'; } @@ -991,7 +975,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIMESTAMP(0) WITH TIME ZONE'; } @@ -999,7 +983,7 @@ public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -1007,7 +991,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME(0) WITHOUT TIME ZONE'; } @@ -1015,7 +999,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { return ''; } @@ -1023,7 +1007,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(255)') : ($length ? 'VARCHAR(' . $length . ')' : 'VARCHAR(255)'); @@ -1032,7 +1016,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return 'BYTEA'; } @@ -1040,7 +1024,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { return 'TEXT'; } @@ -1048,7 +1032,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'postgresql'; } @@ -1058,7 +1042,7 @@ public function getName() * * PostgreSQL returns all column names in SQL result sets in lowercase. */ - public function getSQLResultCasing($column) + public function getSQLResultCasing(string $column) : string { return strtolower($column); } @@ -1066,7 +1050,7 @@ public function getSQLResultCasing($column) /** * {@inheritDoc} */ - public function getDateTimeTzFormatString() + public function getDateTimeTzFormatString() : string { return 'Y-m-d H:i:sO'; } @@ -1074,15 +1058,15 @@ public function getDateTimeTzFormatString() /** * {@inheritDoc} */ - public function getEmptyIdentityInsertSQL($quotedTableName, $quotedIdentifierColumnName) + public function getEmptyIdentityInsertSQL(string $tableName, string $identifierColumnName) : string { - return 'INSERT INTO ' . $quotedTableName . ' (' . $quotedIdentifierColumnName . ') VALUES (DEFAULT)'; + return 'INSERT INTO ' . $tableName . ' (' . $identifierColumnName . ') VALUES (DEFAULT)'; } /** * {@inheritDoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); $sql = 'TRUNCATE ' . $tableIdentifier->getQuotedName($this); @@ -1097,7 +1081,7 @@ public function getTruncateTableSQL($tableName, $cascade = false) /** * {@inheritDoc} */ - public function getReadLockSQL() + public function getReadLockSQL() : string { return 'FOR SHARE'; } @@ -1105,7 +1089,7 @@ public function getReadLockSQL() /** * {@inheritDoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', @@ -1154,7 +1138,7 @@ protected function initializeDoctrineTypeMappings() /** * {@inheritDoc} */ - public function getVarcharMaxLength() + public function getVarcharMaxLength() : int { return 65535; } @@ -1162,7 +1146,7 @@ public function getVarcharMaxLength() /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 0; } @@ -1170,7 +1154,7 @@ public function getBinaryMaxLength() /** * {@inheritdoc} */ - public function getBinaryDefaultLength() + public function getBinaryDefaultLength() : int { return 0; } @@ -1178,7 +1162,7 @@ public function getBinaryDefaultLength() /** * {@inheritdoc} */ - public function hasNativeJsonType() + public function hasNativeJsonType() : bool { return true; } @@ -1186,7 +1170,7 @@ public function hasNativeJsonType() /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\PostgreSQLKeywords::class; } @@ -1194,7 +1178,7 @@ protected function getReservedKeywordsClass() /** * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { return 'BYTEA'; } @@ -1202,7 +1186,7 @@ public function getBlobTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - public function getDefaultValueDeclarationSQL($field) + public function getDefaultValueDeclarationSQL(array $field) : string { if ($this->isSerialField($field)) { return ''; @@ -1214,7 +1198,7 @@ public function getDefaultValueDeclarationSQL($field) /** * {@inheritdoc} */ - public function supportsColumnCollation() + public function supportsColumnCollation() : bool { return true; } @@ -1222,7 +1206,7 @@ public function supportsColumnCollation() /** * {@inheritdoc} */ - public function getColumnCollationDeclarationSQL($collation) + public function getColumnCollationDeclarationSQL(string $collation) : string { return 'COLLATE ' . $this->quoteSingleIdentifier($collation); } @@ -1230,7 +1214,7 @@ public function getColumnCollationDeclarationSQL($collation) /** * {@inheritdoc} */ - public function getJsonTypeDeclarationSQL(array $field) + public function getJsonTypeDeclarationSQL(array $field) : string { return 'JSON'; } @@ -1250,7 +1234,7 @@ private function isSerialField(array $field) : bool */ private function typeChangeBreaksDefaultValue(ColumnDiff $columnDiff) : bool { - if (! $columnDiff->fromColumn) { + if ($columnDiff->fromColumn === null) { return $columnDiff->hasChanged('type'); } @@ -1269,7 +1253,11 @@ private function isNumericType(Type $type) : bool private function getOldColumnComment(ColumnDiff $columnDiff) : ?string { - return $columnDiff->fromColumn ? $this->getColumnComment($columnDiff->fromColumn) : null; + if ($columnDiff->fromColumn === null) { + return null; + } + + return $this->getColumnComment($columnDiff->fromColumn); } public function getListTableMetadataSQL(string $table, ?string $schema = null) : string diff --git a/lib/Doctrine/DBAL/Platforms/SQLAnywherePlatform.php b/lib/Doctrine/DBAL/Platforms/SQLAnywherePlatform.php index 2c7114d3310..b3f370cc4e4 100644 --- a/lib/Doctrine/DBAL/Platforms/SQLAnywherePlatform.php +++ b/lib/Doctrine/DBAL/Platforms/SQLAnywherePlatform.php @@ -48,7 +48,7 @@ class SQLAnywherePlatform extends AbstractPlatform /** * {@inheritdoc} */ - public function appendLockHint($fromClause, $lockMode) + public function appendLockHint(string $fromClause, ?int $lockMode) : string { switch (true) { case $lockMode === LockMode::NONE: @@ -70,7 +70,7 @@ public function appendLockHint($fromClause, $lockMode) * * SQL Anywhere supports a maximum length of 128 bytes for identifiers. */ - public function fixSchemaElementName($schemaElementName) + public function fixSchemaElementName(string $schemaElementName) : string { $maxIdentifierLength = $this->getMaxIdentifierLength(); @@ -84,7 +84,7 @@ public function fixSchemaElementName($schemaElementName) /** * {@inheritdoc} */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $query = ''; @@ -112,7 +112,7 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey /** * {@inheritdoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $sql = []; $columnSql = []; @@ -209,10 +209,8 @@ public function getAlterTableSQL(TableDiff $diff) * Returns the SQL clause for creating a column in a table alteration. * * @param Column $column The column to add. - * - * @return string */ - protected function getAlterTableAddColumnClause(Column $column) + protected function getAlterTableAddColumnClause(Column $column) : string { return 'ADD ' . $this->getColumnDeclarationSQL($column->getQuotedName($this), $column->toArray()); } @@ -221,10 +219,8 @@ protected function getAlterTableAddColumnClause(Column $column) * Returns the SQL clause for altering a table. * * @param Identifier $tableName The quoted name of the table to alter. - * - * @return string */ - protected function getAlterTableClause(Identifier $tableName) + protected function getAlterTableClause(Identifier $tableName) : string { return 'ALTER TABLE ' . $tableName->getQuotedName($this); } @@ -233,10 +229,8 @@ protected function getAlterTableClause(Identifier $tableName) * Returns the SQL clause for dropping a column in a table alteration. * * @param Column $column The column to drop. - * - * @return string */ - protected function getAlterTableRemoveColumnClause(Column $column) + protected function getAlterTableRemoveColumnClause(Column $column) : string { return 'DROP ' . $column->getQuotedName($this); } @@ -246,10 +240,8 @@ protected function getAlterTableRemoveColumnClause(Column $column) * * @param string $oldColumnName The quoted name of the column to rename. * @param Column $column The column to rename to. - * - * @return string */ - protected function getAlterTableRenameColumnClause($oldColumnName, Column $column) + protected function getAlterTableRenameColumnClause(string $oldColumnName, Column $column) : string { $oldColumnName = new Identifier($oldColumnName); @@ -260,10 +252,8 @@ protected function getAlterTableRenameColumnClause($oldColumnName, Column $colum * Returns the SQL clause for renaming a table in a table alteration. * * @param Identifier $newTableName The quoted name of the table to rename to. - * - * @return string */ - protected function getAlterTableRenameTableClause(Identifier $newTableName) + protected function getAlterTableRenameTableClause(Identifier $newTableName) : string { return 'RENAME ' . $newTableName->getQuotedName($this); } @@ -275,10 +265,8 @@ protected function getAlterTableRenameTableClause(Identifier $newTableName) * Changes in column comments have to be handled differently. * * @param ColumnDiff $columnDiff The diff of the column to alter. - * - * @return string|null */ - protected function getAlterTableChangeColumnClause(ColumnDiff $columnDiff) + protected function getAlterTableChangeColumnClause(ColumnDiff $columnDiff) : ?string { $column = $columnDiff->column; @@ -300,7 +288,7 @@ protected function getAlterTableChangeColumnClause(ColumnDiff $columnDiff) /** * {@inheritdoc} */ - public function getBigIntTypeDeclarationSQL(array $columnDef) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { $columnDef['integer_type'] = 'BIGINT'; @@ -310,7 +298,7 @@ public function getBigIntTypeDeclarationSQL(array $columnDef) /** * {@inheritdoc} */ - public function getBinaryDefaultLength() + public function getBinaryDefaultLength() : int { return 1; } @@ -318,7 +306,7 @@ public function getBinaryDefaultLength() /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 32767; } @@ -326,7 +314,7 @@ public function getBinaryMaxLength() /** * {@inheritdoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { return 'LONG BINARY'; } @@ -339,7 +327,7 @@ public function getBlobTypeDeclarationSQL(array $field) * Otherwise by just omitting the NOT NULL clause, * SQL Anywhere will declare them NOT NULL nonetheless. */ - public function getBooleanTypeDeclarationSQL(array $columnDef) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { $nullClause = isset($columnDef['notnull']) && (bool) $columnDef['notnull'] === false ? ' NULL' : ''; @@ -349,7 +337,7 @@ public function getBooleanTypeDeclarationSQL(array $columnDef) /** * {@inheritdoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { return 'TEXT'; } @@ -357,7 +345,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - public function getCommentOnColumnSQL($tableName, $columnName, $comment) + public function getCommentOnColumnSQL(string $tableName, string $columnName, ?string $comment) : string { $tableName = new Identifier($tableName); $columnName = new Identifier($columnName); @@ -382,7 +370,7 @@ public function getConcatExpression(string ...$string) : string /** * {@inheritdoc} */ - public function getCreateConstraintSQL(Constraint $constraint, $table) + public function getCreateConstraintSQL(Constraint $constraint, $table) : string { if ($constraint instanceof ForeignKeyConstraint) { return $this->getCreateForeignKeySQL($constraint, $table); @@ -399,7 +387,7 @@ public function getCreateConstraintSQL(Constraint $constraint, $table) /** * {@inheritdoc} */ - public function getCreateDatabaseSQL($database) + public function getCreateDatabaseSQL(string $database) : string { $database = new Identifier($database); @@ -411,7 +399,7 @@ public function getCreateDatabaseSQL($database) * * Appends SQL Anywhere specific flags if given. */ - public function getCreateIndexSQL(Index $index, $table) + public function getCreateIndexSQL(Index $index, $table) : string { return parent::getCreateIndexSQL($index, $table) . $this->getAdvancedIndexOptionsSQL($index); } @@ -419,7 +407,7 @@ public function getCreateIndexSQL(Index $index, $table) /** * {@inheritdoc} */ - public function getCreatePrimaryKeySQL(Index $index, $table) + public function getCreatePrimaryKeySQL(Index $index, $table) : string { if ($table instanceof Table) { $table = $table->getQuotedName($this); @@ -431,7 +419,7 @@ public function getCreatePrimaryKeySQL(Index $index, $table) /** * {@inheritdoc} */ - public function getCreateTemporaryTableSnippetSQL() + public function getCreateTemporaryTableSnippetSQL() : string { return 'CREATE ' . $this->getTemporaryTableSQL() . ' TABLE'; } @@ -439,7 +427,7 @@ public function getCreateTemporaryTableSnippetSQL() /** * {@inheritdoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -447,7 +435,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritdoc} */ - public function getCurrentDateSQL() + public function getCurrentDateSQL() : string { return 'CURRENT DATE'; } @@ -455,7 +443,7 @@ public function getCurrentDateSQL() /** * {@inheritdoc} */ - public function getCurrentTimeSQL() + public function getCurrentTimeSQL() : string { return 'CURRENT TIME'; } @@ -463,7 +451,7 @@ public function getCurrentTimeSQL() /** * {@inheritdoc} */ - public function getCurrentTimestampSQL() + public function getCurrentTimestampSQL() : string { return 'CURRENT TIMESTAMP'; } @@ -493,7 +481,7 @@ public function getDateDiffExpression(string $date1, string $date2) : string /** * {@inheritdoc} */ - public function getDateTimeFormatString() + public function getDateTimeFormatString() : string { return 'Y-m-d H:i:s.u'; } @@ -501,7 +489,7 @@ public function getDateTimeFormatString() /** * {@inheritdoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATETIME'; } @@ -509,7 +497,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritdoc} */ - public function getDateTimeTzFormatString() + public function getDateTimeTzFormatString() : string { return 'Y-m-d H:i:s.uP'; } @@ -517,7 +505,7 @@ public function getDateTimeTzFormatString() /** * {@inheritdoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -525,7 +513,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritdoc} */ - public function getDefaultTransactionIsolationLevel() + public function getDefaultTransactionIsolationLevel() : int { return TransactionIsolationLevel::READ_UNCOMMITTED; } @@ -533,7 +521,7 @@ public function getDefaultTransactionIsolationLevel() /** * {@inheritdoc} */ - public function getDropDatabaseSQL($database) + public function getDropDatabaseSQL(string $database) : string { $database = new Identifier($database); @@ -543,7 +531,7 @@ public function getDropDatabaseSQL($database) /** * {@inheritdoc} */ - public function getDropIndexSQL($index, $table = null) + public function getDropIndexSQL($index, $table = null) : string { if ($index instanceof Index) { $index = $index->getQuotedName($this); @@ -575,7 +563,7 @@ public function getDropIndexSQL($index, $table = null) /** * {@inheritdoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -583,7 +571,7 @@ public function getDropViewSQL($name) /** * {@inheritdoc} */ - public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey) + public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey) : string { $sql = ''; $foreignKeyName = $foreignKey->getName(); @@ -622,13 +610,11 @@ public function getForeignKeyBaseDeclarationSQL(ForeignKeyConstraint $foreignKey * * @param int $type The foreign key match type * - * @return string - * * @throws InvalidArgumentException If unknown match type given. */ - public function getForeignKeyMatchClauseSQL($type) + public function getForeignKeyMatchClauseSQL(int $type) : string { - switch ((int) $type) { + switch ($type) { case self::FOREIGN_KEY_MATCH_SIMPLE: return 'SIMPLE'; @@ -651,7 +637,7 @@ public function getForeignKeyMatchClauseSQL($type) /** * {@inheritdoc} */ - public function getForeignKeyReferentialActionSQL($action) + public function getForeignKeyReferentialActionSQL(string $action) : string { // NO ACTION is not supported, therefore falling back to RESTRICT. if (strtoupper($action) === 'NO ACTION') { @@ -664,7 +650,7 @@ public function getForeignKeyReferentialActionSQL($action) /** * {@inheritdoc} */ - public function getForUpdateSQL() + public function getForUpdateSQL() : string { return ''; } @@ -672,7 +658,7 @@ public function getForUpdateSQL() /** * {@inheritdoc} */ - public function getGuidTypeDeclarationSQL(array $field) + public function getGuidTypeDeclarationSQL(array $field) : string { return 'UNIQUEIDENTIFIER'; } @@ -680,7 +666,7 @@ public function getGuidTypeDeclarationSQL(array $field) /** * {@inheritdoc} */ - public function getIndexDeclarationSQL($name, Index $index) + public function getIndexDeclarationSQL(string $name, Index $index) : string { // Index declaration in statements like CREATE TABLE is not supported. throw NotSupported::new(__METHOD__); @@ -689,7 +675,7 @@ public function getIndexDeclarationSQL($name, Index $index) /** * {@inheritdoc} */ - public function getIntegerTypeDeclarationSQL(array $columnDef) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { $columnDef['integer_type'] = 'INT'; @@ -699,7 +685,7 @@ public function getIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritdoc} */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { return 'SELECT db_name(number) AS name FROM sa_db_list()'; } @@ -707,7 +693,7 @@ public function getListDatabasesSQL() /** * {@inheritdoc} */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { $user = 'USER_NAME()'; @@ -746,7 +732,7 @@ public function getListTableColumnsSQL($table, $database = null) * * @todo Where is this used? Which information should be retrieved? */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { $user = ''; @@ -775,7 +761,7 @@ public function getListTableConstraintsSQL($table) /** * {@inheritdoc} */ - public function getListTableForeignKeysSQL($table) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { $user = ''; @@ -868,7 +854,7 @@ public function getListTableForeignKeysSQL($table) /** * {@inheritdoc} */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { $user = ''; @@ -928,7 +914,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritdoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return "SELECT tbl.table_name FROM SYS.SYSTAB AS tbl @@ -945,7 +931,7 @@ public function getListTablesSQL() * * @todo Where is this used? Which information should be retrieved? */ - public function getListUsersSQL() + public function getListUsersSQL() : string { return 'SELECT * FROM SYS.SYSUSER ORDER BY user_name ASC'; } @@ -953,7 +939,7 @@ public function getListUsersSQL() /** * {@inheritdoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return "SELECT tbl.table_name, v.view_def FROM SYS.SYSVIEW v @@ -979,7 +965,7 @@ public function getLocateExpression(string $string, string $substring, ?string $ /** * {@inheritdoc} */ - public function getMaxIdentifierLength() + public function getMaxIdentifierLength() : int { return 128; } @@ -1003,7 +989,7 @@ public function getRegexpExpression() : string /** * {@inheritdoc} */ - public function getName() + public function getName() : string { return 'sqlanywhere'; } @@ -1019,7 +1005,7 @@ public function getName() * * @throws InvalidArgumentException If the given index is not a primary key. */ - public function getPrimaryKeyDeclarationSQL(Index $index, $name = null) + public function getPrimaryKeyDeclarationSQL(Index $index, ?string $name = null) : string { if (! $index->isPrimary()) { throw new InvalidArgumentException( @@ -1033,7 +1019,7 @@ public function getPrimaryKeyDeclarationSQL(Index $index, $name = null) /** * {@inheritdoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'SET TEMPORARY OPTION isolation_level = ' . $this->_getTransactionIsolationLevelSQL($level); } @@ -1041,7 +1027,7 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritdoc} */ - public function getSmallIntTypeDeclarationSQL(array $columnDef) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { $columnDef['integer_type'] = 'SMALLINT'; @@ -1058,10 +1044,8 @@ public function getSmallIntTypeDeclarationSQL(array $columnDef) * SQL Anywhere does not automatically start a database after creation! * * @param string $database Name of the database to start. - * - * @return string */ - public function getStartDatabaseSQL($database) + public function getStartDatabaseSQL(string $database) : string { $database = new Identifier($database); @@ -1077,10 +1061,8 @@ public function getStartDatabaseSQL($database) * as it has to be explicitly stopped before it can be dropped. * * @param string $database Name of the database to stop. - * - * @return string */ - public function getStopDatabaseSQL($database) + public function getStopDatabaseSQL(string $database) : string { $database = new Identifier($database); @@ -1102,7 +1084,7 @@ public function getSubstringExpression(string $string, string $start, ?string $l /** * {@inheritdoc} */ - public function getTemporaryTableSQL() + public function getTemporaryTableSQL() : string { return 'GLOBAL TEMPORARY'; } @@ -1110,7 +1092,7 @@ public function getTemporaryTableSQL() /** * {@inheritdoc} */ - public function getTimeFormatString() + public function getTimeFormatString() : string { return 'H:i:s.u'; } @@ -1118,7 +1100,7 @@ public function getTimeFormatString() /** * {@inheritdoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME'; } @@ -1161,7 +1143,7 @@ public function getTrimExpression(string $str, int $mode = TrimMode::UNSPECIFIED /** * {@inheritdoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); @@ -1171,7 +1153,7 @@ public function getTruncateTableSQL($tableName, $cascade = false) /** * {@inheritdoc} */ - public function getCreateSequenceSQL(Sequence $sequence) + public function getCreateSequenceSQL(Sequence $sequence) : string { return 'CREATE SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize() . @@ -1182,7 +1164,7 @@ public function getCreateSequenceSQL(Sequence $sequence) /** * {@inheritdoc} */ - public function getAlterSequenceSQL(Sequence $sequence) + public function getAlterSequenceSQL(Sequence $sequence) : string { return 'ALTER SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize(); @@ -1191,7 +1173,7 @@ public function getAlterSequenceSQL(Sequence $sequence) /** * {@inheritdoc} */ - public function getDropSequenceSQL($sequence) + public function getDropSequenceSQL($sequence) : string { if ($sequence instanceof Sequence) { $sequence = $sequence->getQuotedName($this); @@ -1203,7 +1185,7 @@ public function getDropSequenceSQL($sequence) /** * {@inheritdoc} */ - public function getListSequencesSQL($database) + public function getListSequencesSQL(string $database) : string { return 'SELECT sequence_name, increment_by, start_with, min_value FROM SYS.SYSSEQUENCE'; } @@ -1211,7 +1193,7 @@ public function getListSequencesSQL($database) /** * {@inheritdoc} */ - public function getSequenceNextValSQL($sequenceName) + public function getSequenceNextValSQL(string $sequenceName) : string { return 'SELECT ' . $sequenceName . '.NEXTVAL'; } @@ -1219,7 +1201,7 @@ public function getSequenceNextValSQL($sequenceName) /** * {@inheritdoc} */ - public function supportsSequences() + public function supportsSequences() : bool { return true; } @@ -1227,7 +1209,7 @@ public function supportsSequences() /** * {@inheritdoc} */ - public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIMESTAMP WITH TIME ZONE'; } @@ -1235,7 +1217,7 @@ public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritdoc} */ - public function getVarcharDefaultLength() + public function getVarcharDefaultLength() : int { return 1; } @@ -1243,7 +1225,7 @@ public function getVarcharDefaultLength() /** * {@inheritdoc} */ - public function getVarcharMaxLength() + public function getVarcharMaxLength() : int { return 32767; } @@ -1251,7 +1233,7 @@ public function getVarcharMaxLength() /** * {@inheritdoc} */ - public function hasNativeGuidType() + public function hasNativeGuidType() : bool { return true; } @@ -1259,7 +1241,7 @@ public function hasNativeGuidType() /** * {@inheritdoc} */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return true; } @@ -1267,7 +1249,7 @@ public function prefersIdentityColumns() /** * {@inheritdoc} */ - public function supportsCommentOnStatement() + public function supportsCommentOnStatement() : bool { return true; } @@ -1275,7 +1257,7 @@ public function supportsCommentOnStatement() /** * {@inheritdoc} */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -1283,7 +1265,7 @@ public function supportsIdentityColumns() /** * {@inheritdoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { $unsigned = ! empty($columnDef['unsigned']) ? 'UNSIGNED ' : ''; $autoincrement = ! empty($columnDef['autoincrement']) ? ' IDENTITY' : ''; @@ -1294,7 +1276,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritdoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $columnListSql = $this->getColumnDeclarationListSQL($columns); $indexSql = []; @@ -1343,17 +1325,17 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options /** * {@inheritdoc} */ - protected function _getTransactionIsolationLevelSQL($level) + protected function _getTransactionIsolationLevelSQL(int $level) : string { switch ($level) { case TransactionIsolationLevel::READ_UNCOMMITTED: - return 0; + return '0'; case TransactionIsolationLevel::READ_COMMITTED: - return 1; + return '1'; case TransactionIsolationLevel::REPEATABLE_READ: - return 2; + return '2'; case TransactionIsolationLevel::SERIALIZABLE: - return 3; + return '3'; default: throw new InvalidArgumentException(sprintf('Invalid isolation level %d.', $level)); } @@ -1391,10 +1373,8 @@ private function getTopClauseSQL(?int $limit, ?int $offset) : string * SQL Anywhere options. * * @param Index $index Index definition - * - * @return string */ - protected function getAdvancedIndexOptionsSQL(Index $index) + protected function getAdvancedIndexOptionsSQL(Index $index) : string { if ($index->hasFlag('with_nulls_distinct') && $index->hasFlag('with_nulls_not_distinct')) { throw new UnexpectedValueException( @@ -1422,7 +1402,7 @@ protected function getAdvancedIndexOptionsSQL(Index $index) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? 'BINARY(' . ($length ?: $this->getBinaryDefaultLength()) . ')' @@ -1435,11 +1415,9 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) * @param Constraint $constraint The table constraint to create the SQL snippet for. * @param string|null $name The table constraint name to use if any. * - * @return string - * * @throws InvalidArgumentException If the given table constraint type is not supported by this method. */ - protected function getTableConstraintDeclarationSQL(Constraint $constraint, $name = null) + protected function getTableConstraintDeclarationSQL(Constraint $constraint, ?string $name = null) : string { if ($constraint instanceof ForeignKeyConstraint) { return $this->getForeignKeyDeclarationSQL($constraint); @@ -1484,7 +1462,7 @@ protected function getTableConstraintDeclarationSQL(Constraint $constraint, $nam /** * {@inheritdoc} */ - protected function getCreateIndexSQLFlags(Index $index) + protected function getCreateIndexSQLFlags(Index $index) : string { $type = ''; if ($index->hasFlag('virtual')) { @@ -1505,7 +1483,7 @@ protected function getCreateIndexSQLFlags(Index $index) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { return ['ALTER INDEX ' . $oldIndexName . ' ON ' . $tableName . ' RENAME TO ' . $index->getQuotedName($this)]; } @@ -1513,7 +1491,7 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) /** * {@inheritdoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\SQLAnywhereKeywords::class; } @@ -1521,7 +1499,7 @@ protected function getReservedKeywordsClass() /** * {@inheritdoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(' . $this->getVarcharDefaultLength() . ')') @@ -1531,7 +1509,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', diff --git a/lib/Doctrine/DBAL/Platforms/SQLAzurePlatform.php b/lib/Doctrine/DBAL/Platforms/SQLAzurePlatform.php index 72e2acfa31b..e3ed527b619 100644 --- a/lib/Doctrine/DBAL/Platforms/SQLAzurePlatform.php +++ b/lib/Doctrine/DBAL/Platforms/SQLAzurePlatform.php @@ -18,7 +18,7 @@ class SQLAzurePlatform extends SQLServerPlatform /** * {@inheritDoc} */ - public function getCreateTableSQL(Table $table, $createFlags = self::CREATE_INDEXES) + public function getCreateTableSQL(Table $table, int $createFlags = self::CREATE_INDEXES) : array { $sql = parent::getCreateTableSQL($table, $createFlags); diff --git a/lib/Doctrine/DBAL/Platforms/SQLServer2012Platform.php b/lib/Doctrine/DBAL/Platforms/SQLServer2012Platform.php index 8066a772ae5..8bd564383b7 100644 --- a/lib/Doctrine/DBAL/Platforms/SQLServer2012Platform.php +++ b/lib/Doctrine/DBAL/Platforms/SQLServer2012Platform.php @@ -22,7 +22,7 @@ class SQLServer2012Platform extends SQLServerPlatform /** * {@inheritdoc} */ - public function getAlterSequenceSQL(Sequence $sequence) + public function getAlterSequenceSQL(Sequence $sequence) : string { return 'ALTER SEQUENCE ' . $sequence->getQuotedName($this) . ' INCREMENT BY ' . $sequence->getAllocationSize(); @@ -31,7 +31,7 @@ public function getAlterSequenceSQL(Sequence $sequence) /** * {@inheritdoc} */ - public function getCreateSequenceSQL(Sequence $sequence) + public function getCreateSequenceSQL(Sequence $sequence) : string { return 'CREATE SEQUENCE ' . $sequence->getQuotedName($this) . ' START WITH ' . $sequence->getInitialValue() . @@ -42,7 +42,7 @@ public function getCreateSequenceSQL(Sequence $sequence) /** * {@inheritdoc} */ - public function getDropSequenceSQL($sequence) + public function getDropSequenceSQL($sequence) : string { if ($sequence instanceof Sequence) { $sequence = $sequence->getQuotedName($this); @@ -54,7 +54,7 @@ public function getDropSequenceSQL($sequence) /** * {@inheritdoc} */ - public function getListSequencesSQL($database) + public function getListSequencesSQL(string $database) : string { return 'SELECT seq.name, CAST( @@ -69,7 +69,7 @@ public function getListSequencesSQL($database) /** * {@inheritdoc} */ - public function getSequenceNextValSQL($sequenceName) + public function getSequenceNextValSQL(string $sequenceName) : string { return 'SELECT NEXT VALUE FOR ' . $sequenceName; } @@ -77,7 +77,7 @@ public function getSequenceNextValSQL($sequenceName) /** * {@inheritdoc} */ - public function supportsSequences() + public function supportsSequences() : bool { return true; } @@ -87,7 +87,7 @@ public function supportsSequences() * * Returns Microsoft SQL Server 2012 specific keywords class */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\SQLServer2012Keywords::class; } diff --git a/lib/Doctrine/DBAL/Platforms/SQLServerPlatform.php b/lib/Doctrine/DBAL/Platforms/SQLServerPlatform.php index c9632387fc1..ad2a4ad20a3 100644 --- a/lib/Doctrine/DBAL/Platforms/SQLServerPlatform.php +++ b/lib/Doctrine/DBAL/Platforms/SQLServerPlatform.php @@ -46,7 +46,7 @@ class SQLServerPlatform extends AbstractPlatform /** * {@inheritdoc} */ - public function getCurrentDateSQL() + public function getCurrentDateSQL() : string { return $this->getConvertExpression('date', 'GETDATE()'); } @@ -54,7 +54,7 @@ public function getCurrentDateSQL() /** * {@inheritdoc} */ - public function getCurrentTimeSQL() + public function getCurrentTimeSQL() : string { return $this->getConvertExpression('time', 'GETDATE()'); } @@ -64,10 +64,8 @@ public function getCurrentTimeSQL() * * @param string $dataType The target native data type. Alias data types cannot be used. * @param string $expression The SQL expression to convert. - * - * @return string */ - private function getConvertExpression($dataType, $expression) + private function getConvertExpression(string $dataType, string $expression) : string { return sprintf('CONVERT(%s, %s)', $dataType, $expression); } @@ -100,7 +98,7 @@ public function getDateDiffExpression(string $date1, string $date2) : string * Microsoft SQL Server prefers "autoincrement" identity columns * since sequences can only be emulated with a table. */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return true; } @@ -110,7 +108,7 @@ public function prefersIdentityColumns() * * Microsoft SQL Server supports this through AUTO_INCREMENT columns. */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -118,7 +116,7 @@ public function supportsIdentityColumns() /** * {@inheritDoc} */ - public function supportsReleaseSavepoints() + public function supportsReleaseSavepoints() : bool { return false; } @@ -126,7 +124,7 @@ public function supportsReleaseSavepoints() /** * {@inheritdoc} */ - public function supportsSchemas() + public function supportsSchemas() : bool { return true; } @@ -134,7 +132,7 @@ public function supportsSchemas() /** * {@inheritdoc} */ - public function getDefaultSchemaName() + public function getDefaultSchemaName() : string { return 'dbo'; } @@ -142,7 +140,7 @@ public function getDefaultSchemaName() /** * {@inheritDoc} */ - public function supportsColumnCollation() + public function supportsColumnCollation() : bool { return true; } @@ -150,7 +148,7 @@ public function supportsColumnCollation() /** * {@inheritDoc} */ - public function hasNativeGuidType() + public function hasNativeGuidType() : bool { return true; } @@ -158,23 +156,23 @@ public function hasNativeGuidType() /** * {@inheritDoc} */ - public function getCreateDatabaseSQL($name) + public function getCreateDatabaseSQL(string $database) : string { - return 'CREATE DATABASE ' . $name; + return 'CREATE DATABASE ' . $database; } /** * {@inheritDoc} */ - public function getDropDatabaseSQL($name) + public function getDropDatabaseSQL(string $database) : string { - return 'DROP DATABASE ' . $name; + return 'DROP DATABASE ' . $database; } /** * {@inheritDoc} */ - public function supportsCreateDropDatabase() + public function supportsCreateDropDatabase() : bool { return true; } @@ -182,7 +180,7 @@ public function supportsCreateDropDatabase() /** * {@inheritDoc} */ - public function getCreateSchemaSQL($schemaName) + public function getCreateSchemaSQL(string $schemaName) : string { return 'CREATE SCHEMA ' . $schemaName; } @@ -190,7 +188,7 @@ public function getCreateSchemaSQL($schemaName) /** * {@inheritDoc} */ - public function getDropForeignKeySQL($foreignKey, $table) + public function getDropForeignKeySQL($foreignKey, $table) : string { if (! $foreignKey instanceof ForeignKeyConstraint) { $foreignKey = new Identifier($foreignKey); @@ -209,7 +207,7 @@ public function getDropForeignKeySQL($foreignKey, $table) /** * {@inheritDoc} */ - public function getDropIndexSQL($index, $table = null) + public function getDropIndexSQL($index, $table = null) : string { if ($index instanceof Index) { $index = $index->getQuotedName($this); @@ -247,7 +245,7 @@ public function getDropIndexSQL($index, $table = null) /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $defaultConstraintsSql = []; $commentsSql = []; @@ -321,7 +319,7 @@ protected function _getCreateTableSQL($tableName, array $columns, array $options /** * {@inheritDoc} */ - public function getCreatePrimaryKeySQL(Index $index, $table) + public function getCreatePrimaryKeySQL(Index $index, $table) : string { if ($table instanceof Table) { $identifier = $table->getQuotedName($this); @@ -352,10 +350,8 @@ public function getCreatePrimaryKeySQL(Index $index, $table) * @param string $tableName The quoted table name to which the column belongs. * @param string $columnName The quoted column name to create the comment for. * @param string|null $comment The column's comment. - * - * @return string */ - protected function getCreateColumnCommentSQL($tableName, $columnName, $comment) + protected function getCreateColumnCommentSQL(string $tableName, string $columnName, ?string $comment) : string { if (strpos($tableName, '.') !== false) { [$schemaSQL, $tableSQL] = explode('.', $tableName); @@ -384,11 +380,9 @@ protected function getCreateColumnCommentSQL($tableName, $columnName, $comment) * @param string $table Name of the table to return the default constraint declaration for. * @param mixed[] $column Column definition. * - * @return string - * * @throws InvalidArgumentException */ - public function getDefaultConstraintDeclarationSQL($table, array $column) + public function getDefaultConstraintDeclarationSQL(string $table, array $column) : string { if (! isset($column['default'])) { throw new InvalidArgumentException('Incomplete column definition. "default" required.'); @@ -405,7 +399,7 @@ public function getDefaultConstraintDeclarationSQL($table, array $column) /** * {@inheritDoc} */ - public function getCreateIndexSQL(Index $index, $table) + public function getCreateIndexSQL(Index $index, $table) : string { $constraint = parent::getCreateIndexSQL($index, $table); @@ -419,7 +413,7 @@ public function getCreateIndexSQL(Index $index, $table) /** * {@inheritDoc} */ - protected function getCreateIndexSQLFlags(Index $index) + protected function getCreateIndexSQLFlags(Index $index) : string { $type = ''; if ($index->isUnique()) { @@ -437,12 +431,8 @@ protected function getCreateIndexSQLFlags(Index $index) /** * Extend unique key constraint with required filters - * - * @param string $sql - * - * @return string */ - private function _appendUniqueConstraintDefinition($sql, Index $index) + private function _appendUniqueConstraintDefinition(string $sql, Index $index) : string { $fields = []; @@ -456,7 +446,7 @@ private function _appendUniqueConstraintDefinition($sql, Index $index) /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $queryParts = []; $sql = []; @@ -624,10 +614,8 @@ public function getAlterTableSQL(TableDiff $diff) * * @param string $tableName The name of the table to generate the clause for. * @param Column $column The column to generate the clause for. - * - * @return string */ - private function getAlterTableAddDefaultConstraintClause($tableName, Column $column) + private function getAlterTableAddDefaultConstraintClause(string $tableName, Column $column) : string { $columnDef = $column->toArray(); $columnDef['name'] = $column->getQuotedName($this); @@ -640,10 +628,8 @@ private function getAlterTableAddDefaultConstraintClause($tableName, Column $col * * @param string $tableName The name of the table to generate the clause for. * @param string $columnName The name of the column to generate the clause for. - * - * @return string */ - private function getAlterTableDropDefaultConstraintClause($tableName, $columnName) + private function getAlterTableDropDefaultConstraintClause(string $tableName, string $columnName) : string { return 'DROP CONSTRAINT ' . $this->generateDefaultConstraintName($tableName, $columnName); } @@ -660,7 +646,7 @@ private function getAlterTableDropDefaultConstraintClause($tableName, $columnNam * * @return bool True if the column alteration requires dropping its default constraint first, false otherwise. */ - private function alterColumnRequiresDropDefaultConstraint(ColumnDiff $columnDiff) + private function alterColumnRequiresDropDefaultConstraint(ColumnDiff $columnDiff) : bool { // We can only decide whether to drop an existing default constraint // if we know the original default value. @@ -699,10 +685,8 @@ private function alterColumnRequiresDropDefaultConstraint(ColumnDiff $columnDiff * @param string $tableName The quoted table name to which the column belongs. * @param string $columnName The quoted column name to alter the comment for. * @param string|null $comment The column's comment. - * - * @return string */ - protected function getAlterColumnCommentSQL($tableName, $columnName, $comment) + protected function getAlterColumnCommentSQL(string $tableName, string $columnName, ?string $comment) : string { if (strpos($tableName, '.') !== false) { [$schemaSQL, $tableSQL] = explode('.', $tableName); @@ -738,10 +722,8 @@ protected function getAlterColumnCommentSQL($tableName, $columnName, $comment) * * @param string $tableName The quoted table name to which the column belongs. * @param string $columnName The quoted column name to drop the comment for. - * - * @return string */ - protected function getDropColumnCommentSQL($tableName, $columnName) + protected function getDropColumnCommentSQL(string $tableName, string $columnName) : string { if (strpos($tableName, '.') !== false) { [$schemaSQL, $tableSQL] = explode('.', $tableName); @@ -766,7 +748,7 @@ protected function getDropColumnCommentSQL($tableName, $columnName) /** * {@inheritdoc} */ - protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) + protected function getRenameIndexSQL(string $oldIndexName, Index $index, string $tableName) : array { return [sprintf( "EXEC sp_RENAME N'%s.%s', N'%s', N'INDEX'", @@ -790,19 +772,17 @@ protected function getRenameIndexSQL($oldIndexName, Index $index, $tableName) * @param string|null $level1Name The name of the object at level 1 the property belongs to. * @param string|null $level2Type The type of the object at level 2 the property belongs to. * @param string|null $level2Name The name of the object at level 2 the property belongs to. - * - * @return string */ public function getAddExtendedPropertySQL( - $name, - $value = null, - $level0Type = null, - $level0Name = null, - $level1Type = null, - $level1Name = null, - $level2Type = null, - $level2Name = null - ) { + string $name, + ?string $value = null, + ?string $level0Type = null, + ?string $level0Name = null, + ?string $level1Type = null, + ?string $level1Name = null, + ?string $level2Type = null, + ?string $level2Name = null + ) : string { return 'EXEC sp_addextendedproperty ' . 'N' . $this->quoteStringLiteral($name) . ', N' . $this->quoteStringLiteral((string) $value) . ', ' . 'N' . $this->quoteStringLiteral((string) $level0Type) . ', ' . $level0Name . ', ' . @@ -822,18 +802,16 @@ public function getAddExtendedPropertySQL( * @param string|null $level1Name The name of the object at level 1 the property belongs to. * @param string|null $level2Type The type of the object at level 2 the property belongs to. * @param string|null $level2Name The name of the object at level 2 the property belongs to. - * - * @return string */ public function getDropExtendedPropertySQL( - $name, - $level0Type = null, - $level0Name = null, - $level1Type = null, - $level1Name = null, - $level2Type = null, - $level2Name = null - ) { + string $name, + ?string $level0Type = null, + ?string $level0Name = null, + ?string $level1Type = null, + ?string $level1Name = null, + ?string $level2Type = null, + ?string $level2Name = null + ) : string { return 'EXEC sp_dropextendedproperty ' . 'N' . $this->quoteStringLiteral($name) . ', ' . 'N' . $this->quoteStringLiteral((string) $level0Type) . ', ' . $level0Name . ', ' . @@ -854,19 +832,17 @@ public function getDropExtendedPropertySQL( * @param string|null $level1Name The name of the object at level 1 the property belongs to. * @param string|null $level2Type The type of the object at level 2 the property belongs to. * @param string|null $level2Name The name of the object at level 2 the property belongs to. - * - * @return string */ public function getUpdateExtendedPropertySQL( - $name, - $value = null, - $level0Type = null, - $level0Name = null, - $level1Type = null, - $level1Name = null, - $level2Type = null, - $level2Name = null - ) { + string $name, + ?string $value = null, + ?string $level0Type = null, + ?string $level0Name = null, + ?string $level1Type = null, + ?string $level1Name = null, + ?string $level2Type = null, + ?string $level2Name = null + ) : string { return 'EXEC sp_updateextendedproperty ' . 'N' . $this->quoteStringLiteral($name) . ', N' . $this->quoteStringLiteral((string) $value) . ', ' . 'N' . $this->quoteStringLiteral((string) $level0Type) . ', ' . $level0Name . ', ' . @@ -877,15 +853,15 @@ public function getUpdateExtendedPropertySQL( /** * {@inheritDoc} */ - public function getEmptyIdentityInsertSQL($quotedTableName, $quotedIdentifierColumnName) + public function getEmptyIdentityInsertSQL(string $tableName, string $identifierColumnName) : string { - return 'INSERT INTO ' . $quotedTableName . ' DEFAULT VALUES'; + return 'INSERT INTO ' . $tableName . ' DEFAULT VALUES'; } /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { // "sysdiagrams" table must be ignored as it's internal SQL Server table for Database Diagrams // Category 2 must be ignored as it is "MS SQL Server 'pseudo-system' object[s]" for replication @@ -895,7 +871,7 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListTableColumnsSQL($table, $database = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { return "SELECT col.name, type.name AS type, @@ -928,7 +904,7 @@ public function getListTableColumnsSQL($table, $database = null) /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table, $database = null) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { return 'SELECT f.name AS ForeignKey, SCHEMA_NAME (f.SCHEMA_ID) AS SchemaName, @@ -950,7 +926,7 @@ public function getListTableForeignKeysSQL($table, $database = null) /** * {@inheritDoc} */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { return "SELECT idx.name AS key_name, col.name AS column_name, @@ -973,7 +949,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -981,7 +957,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return "SELECT name FROM sysobjects WHERE type = 'V' ORDER BY name"; } @@ -992,10 +968,8 @@ public function getListViewsSQL($database) * @param string $table The full qualified name of the table. * @param string $schemaColumn The name of the column to compare the schema to in the where clause. * @param string $tableColumn The name of the column to compare the table to in the where clause. - * - * @return string */ - private function getTableWhereClause($table, $schemaColumn, $tableColumn) + private function getTableWhereClause(string $table, string $schemaColumn, string $tableColumn) : string { if (strpos($table, '.') !== false) { [$schema, $table] = explode('.', $table); @@ -1012,7 +986,7 @@ private function getTableWhereClause($table, $schemaColumn, $tableColumn) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -1094,7 +1068,7 @@ public function getConcatExpression(string ...$string) : string /** * {@inheritDoc} */ - public function getListDatabasesSQL() + public function getListDatabasesSQL() : string { return 'SELECT * FROM sys.databases'; } @@ -1102,7 +1076,7 @@ public function getListDatabasesSQL() /** * {@inheritDoc} */ - public function getListNamespacesSQL() + public function getListNamespacesSQL() : string { return "SELECT name FROM sys.schemas WHERE name NOT IN('guest', 'INFORMATION_SCHEMA', 'sys')"; } @@ -1130,7 +1104,7 @@ public function getLengthExpression(string $string) : string /** * {@inheritDoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'SET TRANSACTION ISOLATION LEVEL ' . $this->_getTransactionIsolationLevelSQL($level); } @@ -1138,31 +1112,31 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $field) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { - return 'INT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'INT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $field) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { - return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $field) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { - return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getGuidTypeDeclarationSQL(array $field) + public function getGuidTypeDeclarationSQL(array $field) : string { return 'UNIQUEIDENTIFIER'; } @@ -1170,7 +1144,7 @@ public function getGuidTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATETIMEOFFSET(6)'; } @@ -1178,7 +1152,7 @@ public function getDateTimeTzTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'NCHAR(' . $length . ')' : 'CHAR(255)') : ($length ? 'NVARCHAR(' . $length . ')' : 'NVARCHAR(255)'); } @@ -1186,7 +1160,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? 'BINARY(' . ($length ?: 255) . ')' : 'VARBINARY(' . ($length ?: 255) . ')'; } @@ -1194,7 +1168,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 8000; } @@ -1202,7 +1176,7 @@ public function getBinaryMaxLength() /** * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { return 'VARCHAR(MAX)'; } @@ -1210,7 +1184,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { return ! empty($columnDef['autoincrement']) ? ' IDENTITY' : ''; } @@ -1218,7 +1192,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { // 3 - microseconds precision length // http://msdn.microsoft.com/en-us/library/ms187819.aspx @@ -1228,7 +1202,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -1236,7 +1210,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME(0)'; } @@ -1244,7 +1218,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $field) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'BIT'; } @@ -1302,12 +1276,8 @@ protected function doModifyLimitQuery(string $query, ?int $limit, int $offset) : /** * Remove ORDER BY clauses in subqueries - they're not supported by SQL Server. * Caveat: will leave ORDER BY in TOP N subqueries. - * - * @param string $query - * - * @return string */ - private function scrubInnerOrderBy($query) + private function scrubInnerOrderBy(string $query) : string { $count = substr_count(strtoupper($query), 'ORDER BY'); $offset = 0; @@ -1358,7 +1328,7 @@ private function scrubInnerOrderBy($query) * * @return bool true if ORDER BY is in a TOP N query, false otherwise */ - private function isOrderByInTopNSubquery($query, $currentPosition) + private function isOrderByInTopNSubquery(string $query, int $currentPosition) : bool { // Grab query text on the same nesting level as the ORDER BY clause we're examining. $subQueryBuffer = ''; @@ -1385,7 +1355,7 @@ private function isOrderByInTopNSubquery($query, $currentPosition) /** * {@inheritDoc} */ - public function supportsLimitOffset() + public function supportsLimitOffset() : bool { return true; } @@ -1413,7 +1383,7 @@ public function convertBooleans($item) /** * {@inheritDoc} */ - public function getCreateTemporaryTableSnippetSQL() + public function getCreateTemporaryTableSnippetSQL() : string { return 'CREATE TABLE'; } @@ -1421,7 +1391,7 @@ public function getCreateTemporaryTableSnippetSQL() /** * {@inheritDoc} */ - public function getTemporaryTableName($tableName) + public function getTemporaryTableName(string $tableName) : string { return '#' . $tableName; } @@ -1429,7 +1399,7 @@ public function getTemporaryTableName($tableName) /** * {@inheritDoc} */ - public function getDateTimeFormatString() + public function getDateTimeFormatString() : string { return 'Y-m-d H:i:s.u'; } @@ -1437,7 +1407,7 @@ public function getDateTimeFormatString() /** * {@inheritDoc} */ - public function getDateFormatString() + public function getDateFormatString() : string { return 'Y-m-d'; } @@ -1445,7 +1415,7 @@ public function getDateFormatString() /** * {@inheritDoc} */ - public function getTimeFormatString() + public function getTimeFormatString() : string { return 'H:i:s'; } @@ -1453,7 +1423,7 @@ public function getTimeFormatString() /** * {@inheritDoc} */ - public function getDateTimeTzFormatString() + public function getDateTimeTzFormatString() : string { return 'Y-m-d H:i:s.u P'; } @@ -1461,7 +1431,7 @@ public function getDateTimeTzFormatString() /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'mssql'; } @@ -1469,7 +1439,7 @@ public function getName() /** * {@inheritDoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', @@ -1507,7 +1477,7 @@ protected function initializeDoctrineTypeMappings() /** * {@inheritDoc} */ - public function createSavePoint($savepoint) + public function createSavePoint(string $savepoint) : string { return 'SAVE TRANSACTION ' . $savepoint; } @@ -1515,7 +1485,7 @@ public function createSavePoint($savepoint) /** * {@inheritDoc} */ - public function releaseSavePoint($savepoint) + public function releaseSavePoint(string $savepoint) : string { return ''; } @@ -1523,7 +1493,7 @@ public function releaseSavePoint($savepoint) /** * {@inheritDoc} */ - public function rollbackSavePoint($savepoint) + public function rollbackSavePoint(string $savepoint) : string { return 'ROLLBACK TRANSACTION ' . $savepoint; } @@ -1531,7 +1501,7 @@ public function rollbackSavePoint($savepoint) /** * {@inheritdoc} */ - public function getForeignKeyReferentialActionSQL($action) + public function getForeignKeyReferentialActionSQL(string $action) : string { // RESTRICT is not supported, therefore falling back to NO ACTION. if (strtoupper($action) === 'RESTRICT') { @@ -1544,7 +1514,7 @@ public function getForeignKeyReferentialActionSQL($action) /** * {@inheritDoc} */ - public function appendLockHint($fromClause, $lockMode) + public function appendLockHint(string $fromClause, ?int $lockMode) : string { switch (true) { case $lockMode === LockMode::NONE: @@ -1564,7 +1534,7 @@ public function appendLockHint($fromClause, $lockMode) /** * {@inheritDoc} */ - public function getForUpdateSQL() + public function getForUpdateSQL() : string { return ' '; } @@ -1572,7 +1542,7 @@ public function getForUpdateSQL() /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\SQLServerKeywords::class; } @@ -1580,7 +1550,7 @@ protected function getReservedKeywordsClass() /** * {@inheritDoc} */ - public function quoteSingleIdentifier($str) + public function quoteSingleIdentifier(string $str) : string { return '[' . str_replace(']', '][', $str) . ']'; } @@ -1588,7 +1558,7 @@ public function quoteSingleIdentifier($str) /** * {@inheritDoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); @@ -1598,7 +1568,7 @@ public function getTruncateTableSQL($tableName, $cascade = false) /** * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { return 'VARBINARY(MAX)'; } @@ -1608,7 +1578,7 @@ public function getBlobTypeDeclarationSQL(array $field) * * Modifies column declaration order as it differs in Microsoft SQL Server. */ - public function getColumnDeclarationSQL($name, array $field) + public function getColumnDeclarationSQL(string $name, array $field) : string { if (isset($field['columnDefinition'])) { $columnDef = $this->getCustomTypeDeclarationSQL($field); @@ -1644,10 +1614,8 @@ protected function getLikeWildcardCharacters() : string * * @param string $table Name of the table to generate the unique default constraint name for. * @param string $column Name of the column in the table to generate the unique default constraint name for. - * - * @return string */ - private function generateDefaultConstraintName($table, $column) + private function generateDefaultConstraintName(string $table, string $column) : string { return 'DF_' . $this->generateIdentifierName($table) . '_' . $this->generateIdentifierName($column); } @@ -1656,10 +1624,8 @@ private function generateDefaultConstraintName($table, $column) * Returns a hash value for a given identifier. * * @param string $identifier Identifier to generate a hash value for. - * - * @return string */ - private function generateIdentifierName($identifier) + private function generateIdentifierName(string $identifier) : string { // Always generate name for unquoted identifiers to ensure consistency. $identifier = new Identifier($identifier); diff --git a/lib/Doctrine/DBAL/Platforms/SqlitePlatform.php b/lib/Doctrine/DBAL/Platforms/SqlitePlatform.php index 3cec0c6d136..ee35409bdd6 100644 --- a/lib/Doctrine/DBAL/Platforms/SqlitePlatform.php +++ b/lib/Doctrine/DBAL/Platforms/SqlitePlatform.php @@ -22,7 +22,6 @@ use function sprintf; use function sqrt; use function str_replace; -use function strlen; use function strpos; use function strtolower; use function trim; @@ -46,7 +45,7 @@ public function getRegexpExpression() : string /** * {@inheritDoc} */ - public function getNowExpression($type = 'timestamp') : string + public function getNowExpression(string $type = 'timestamp') : string { switch ($type) { case 'time': @@ -155,15 +154,15 @@ public function getDateDiffExpression(string $date1, string $date2) : string /** * {@inheritDoc} */ - protected function _getTransactionIsolationLevelSQL($level) + protected function _getTransactionIsolationLevelSQL(int $level) : string { switch ($level) { case TransactionIsolationLevel::READ_UNCOMMITTED: - return 0; + return '0'; case TransactionIsolationLevel::READ_COMMITTED: case TransactionIsolationLevel::REPEATABLE_READ: case TransactionIsolationLevel::SERIALIZABLE: - return 1; + return '1'; default: return parent::_getTransactionIsolationLevelSQL($level); } @@ -172,7 +171,7 @@ protected function _getTransactionIsolationLevelSQL($level) /** * {@inheritDoc} */ - public function getSetTransactionIsolationSQL($level) + public function getSetTransactionIsolationSQL(int $level) : string { return 'PRAGMA read_uncommitted = ' . $this->_getTransactionIsolationLevelSQL($level); } @@ -180,7 +179,7 @@ public function getSetTransactionIsolationSQL($level) /** * {@inheritDoc} */ - public function prefersIdentityColumns() + public function prefersIdentityColumns() : bool { return true; } @@ -188,7 +187,7 @@ public function prefersIdentityColumns() /** * {@inheritDoc} */ - public function getBooleanTypeDeclarationSQL(array $field) + public function getBooleanTypeDeclarationSQL(array $columnDef) : string { return 'BOOLEAN'; } @@ -196,28 +195,28 @@ public function getBooleanTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getIntegerTypeDeclarationSQL(array $field) + public function getIntegerTypeDeclarationSQL(array $columnDef) : string { - return 'INTEGER' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'INTEGER' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getBigIntTypeDeclarationSQL(array $field) + public function getBigIntTypeDeclarationSQL(array $columnDef) : string { // SQLite autoincrement is implicit for INTEGER PKs, but not for BIGINT fields. - if (! empty($field['autoincrement'])) { - return $this->getIntegerTypeDeclarationSQL($field); + if (! empty($columnDef['autoincrement'])) { + return $this->getIntegerTypeDeclarationSQL($columnDef); } - return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'BIGINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getTinyIntTypeDeclarationSql(array $field) + public function getTinyIntTypeDeclarationSql(array $field) : string { // SQLite autoincrement is implicit for INTEGER PKs, but not for TINYINT fields. if (! empty($field['autoincrement'])) { @@ -230,20 +229,20 @@ public function getTinyIntTypeDeclarationSql(array $field) /** * {@inheritDoc} */ - public function getSmallIntTypeDeclarationSQL(array $field) + public function getSmallIntTypeDeclarationSQL(array $columnDef) : string { // SQLite autoincrement is implicit for INTEGER PKs, but not for SMALLINT fields. - if (! empty($field['autoincrement'])) { - return $this->getIntegerTypeDeclarationSQL($field); + if (! empty($columnDef['autoincrement'])) { + return $this->getIntegerTypeDeclarationSQL($columnDef); } - return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($field); + return 'SMALLINT' . $this->_getCommonIntegerTypeDeclarationSQL($columnDef); } /** * {@inheritDoc} */ - public function getMediumIntTypeDeclarationSql(array $field) + public function getMediumIntTypeDeclarationSql(array $field) : string { // SQLite autoincrement is implicit for INTEGER PKs, but not for MEDIUMINT fields. if (! empty($field['autoincrement'])) { @@ -256,7 +255,7 @@ public function getMediumIntTypeDeclarationSql(array $field) /** * {@inheritDoc} */ - public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATETIME'; } @@ -264,7 +263,7 @@ public function getDateTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getDateTypeDeclarationSQL(array $fieldDeclaration) + public function getDateTypeDeclarationSQL(array $fieldDeclaration) : string { return 'DATE'; } @@ -272,7 +271,7 @@ public function getDateTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - public function getTimeTypeDeclarationSQL(array $fieldDeclaration) + public function getTimeTypeDeclarationSQL(array $fieldDeclaration) : string { return 'TIME'; } @@ -280,7 +279,7 @@ public function getTimeTypeDeclarationSQL(array $fieldDeclaration) /** * {@inheritDoc} */ - protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) + protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) : string { // sqlite autoincrement is only possible for the primary key if (! empty($columnDef['autoincrement'])) { @@ -293,7 +292,7 @@ protected function _getCommonIntegerTypeDeclarationSQL(array $columnDef) /** * {@inheritDoc} */ - public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) + public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) : string { return parent::getForeignKeyDeclarationSQL(new ForeignKeyConstraint( $foreignKey->getQuotedLocalColumns($this), @@ -307,7 +306,7 @@ public function getForeignKeyDeclarationSQL(ForeignKeyConstraint $foreignKey) /** * {@inheritDoc} */ - protected function _getCreateTableSQL($tableName, array $columns, array $options = []) + protected function _getCreateTableSQL(string $tableName, array $columns, array $options = []) : array { $tableName = str_replace('.', '__', $tableName); $queryFields = $this->getColumnDeclarationListSQL($columns); @@ -380,7 +379,7 @@ private function getNonAutoincrementPrimaryKeyDefinition(array $columns, array $ /** * {@inheritDoc} */ - protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) + protected function getVarcharTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return $fixed ? ($length ? 'CHAR(' . $length . ')' : 'CHAR(255)') @@ -390,7 +389,7 @@ protected function getVarcharTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) + protected function getBinaryTypeDeclarationSQLSnippet(int $length, bool $fixed) : string { return 'BLOB'; } @@ -398,7 +397,7 @@ protected function getBinaryTypeDeclarationSQLSnippet($length, $fixed) /** * {@inheritdoc} */ - public function getBinaryMaxLength() + public function getBinaryMaxLength() : int { return 0; } @@ -406,7 +405,7 @@ public function getBinaryMaxLength() /** * {@inheritdoc} */ - public function getBinaryDefaultLength() + public function getBinaryDefaultLength() : int { return 0; } @@ -414,7 +413,7 @@ public function getBinaryDefaultLength() /** * {@inheritDoc} */ - public function getClobTypeDeclarationSQL(array $field) + public function getClobTypeDeclarationSQL(array $field) : string { return 'CLOB'; } @@ -422,7 +421,7 @@ public function getClobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getListTableConstraintsSQL($table) + public function getListTableConstraintsSQL(string $table) : string { $table = str_replace('.', '__', $table); @@ -435,7 +434,7 @@ public function getListTableConstraintsSQL($table) /** * {@inheritDoc} */ - public function getListTableColumnsSQL($table, $currentDatabase = null) + public function getListTableColumnsSQL(string $table, ?string $database = null) : string { $table = str_replace('.', '__', $table); @@ -445,7 +444,7 @@ public function getListTableColumnsSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getListTableIndexesSQL($table, $currentDatabase = null) + public function getListTableIndexesSQL(string $table, ?string $currentDatabase = null) : string { $table = str_replace('.', '__', $table); @@ -455,7 +454,7 @@ public function getListTableIndexesSQL($table, $currentDatabase = null) /** * {@inheritDoc} */ - public function getListTablesSQL() + public function getListTablesSQL() : string { return "SELECT name FROM sqlite_master WHERE type = 'table' AND name != 'sqlite_sequence' AND name != 'geometry_columns' AND name != 'spatial_ref_sys' " . 'UNION ALL SELECT name FROM sqlite_temp_master ' @@ -465,7 +464,7 @@ public function getListTablesSQL() /** * {@inheritDoc} */ - public function getListViewsSQL($database) + public function getListViewsSQL(string $database) : string { return "SELECT name, sql FROM sqlite_master WHERE type='view' AND sql NOT NULL"; } @@ -473,7 +472,7 @@ public function getListViewsSQL($database) /** * {@inheritDoc} */ - public function getCreateViewSQL($name, $sql) + public function getCreateViewSQL(string $name, string $sql) : string { return 'CREATE VIEW ' . $name . ' AS ' . $sql; } @@ -481,7 +480,7 @@ public function getCreateViewSQL($name, $sql) /** * {@inheritDoc} */ - public function getDropViewSQL($name) + public function getDropViewSQL(string $name) : string { return 'DROP VIEW ' . $name; } @@ -489,7 +488,7 @@ public function getDropViewSQL($name) /** * {@inheritDoc} */ - public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) + public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey) : string { $query = parent::getAdvancedForeignKeyOptionsSQL($foreignKey); @@ -502,7 +501,7 @@ public function getAdvancedForeignKeyOptionsSQL(ForeignKeyConstraint $foreignKey /** * {@inheritDoc} */ - public function supportsIdentityColumns() + public function supportsIdentityColumns() : bool { return true; } @@ -510,7 +509,7 @@ public function supportsIdentityColumns() /** * {@inheritDoc} */ - public function supportsColumnCollation() + public function supportsColumnCollation() : bool { return true; } @@ -518,7 +517,7 @@ public function supportsColumnCollation() /** * {@inheritDoc} */ - public function supportsInlineColumnComments() + public function supportsInlineColumnComments() : bool { return true; } @@ -526,7 +525,7 @@ public function supportsInlineColumnComments() /** * {@inheritDoc} */ - public function getName() + public function getName() : string { return 'sqlite'; } @@ -534,7 +533,7 @@ public function getName() /** * {@inheritDoc} */ - public function getTruncateTableSQL($tableName, $cascade = false) + public function getTruncateTableSQL(string $tableName, bool $cascade = false) : string { $tableIdentifier = new Identifier($tableName); $tableName = str_replace('.', '__', $tableIdentifier->getQuotedName($this)); @@ -546,35 +545,21 @@ public function getTruncateTableSQL($tableName, $cascade = false) * User-defined function for Sqlite that is used with PDO::sqliteCreateFunction(). * * @param int|float $value - * - * @return float */ - public static function udfSqrt($value) + public static function udfSqrt($value) : float { return sqrt($value); } /** * User-defined function for Sqlite that implements MOD(a, b). - * - * @param int $a - * @param int $b - * - * @return int */ - public static function udfMod($a, $b) + public static function udfMod(int $a, int $b) : int { return $a % $b; } - /** - * @param string $str - * @param string $substr - * @param int $offset - * - * @return int - */ - public static function udfLocate($str, $substr, $offset = 0) + public static function udfLocate(string $str, string $substr, int $offset = 0) : int { // SQL's LOCATE function works on 1-based positions, while PHP's strpos works on 0-based positions. // So we have to make them compatible if an offset is given. @@ -594,7 +579,7 @@ public static function udfLocate($str, $substr, $offset = 0) /** * {@inheritDoc} */ - public function getForUpdateSql() + public function getForUpdateSql() : string { return ''; } @@ -602,8 +587,12 @@ public function getForUpdateSql() /** * {@inheritDoc} */ - public function getInlineColumnCommentSQL($comment) + public function getInlineColumnCommentSQL(?string $comment) : string { + if ($comment === null || $comment === '') { + return ''; + } + return '--' . str_replace("\n", "\n--", $comment) . "\n"; } @@ -615,7 +604,7 @@ private function getInlineTableCommentSQL(string $comment) : string /** * {@inheritDoc} */ - protected function initializeDoctrineTypeMappings() + protected function initializeDoctrineTypeMappings() : void { $this->doctrineTypeMapping = [ 'bigint' => 'bigint', @@ -657,7 +646,7 @@ protected function initializeDoctrineTypeMappings() /** * {@inheritDoc} */ - protected function getReservedKeywordsClass() + protected function getReservedKeywordsClass() : string { return Keywords\SQLiteKeywords::class; } @@ -665,7 +654,7 @@ protected function getReservedKeywordsClass() /** * {@inheritDoc} */ - protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) : array { if (! $diff->fromTable instanceof Table) { throw new DBALException('Sqlite platform requires for alter table the table diff with reference to original table schema.'); @@ -686,7 +675,7 @@ protected function getPreAlterTableIndexForeignKeySQL(TableDiff $diff) /** * {@inheritDoc} */ - protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) + protected function getPostAlterTableIndexForeignKeySQL(TableDiff $diff) : array { if (! $diff->fromTable instanceof Table) { throw new DBALException('Sqlite platform requires for alter table the table diff with reference to original table schema.'); @@ -725,7 +714,7 @@ protected function doModifyLimitQuery(string $query, ?int $limit, int $offset) : /** * {@inheritDoc} */ - public function getBlobTypeDeclarationSQL(array $field) + public function getBlobTypeDeclarationSQL(array $field) : string { return 'BLOB'; } @@ -733,7 +722,7 @@ public function getBlobTypeDeclarationSQL(array $field) /** * {@inheritDoc} */ - public function getTemporaryTableName($tableName) + public function getTemporaryTableName(string $tableName) : string { $tableName = str_replace('.', '__', $tableName); @@ -749,7 +738,7 @@ public function getTemporaryTableName($tableName) * This hack is implemented to be able to use SQLite as testdriver when * using schema supporting databases. */ - public function canEmulateSchemas() + public function canEmulateSchemas() : bool { return true; } @@ -757,7 +746,7 @@ public function canEmulateSchemas() /** * {@inheritDoc} */ - public function supportsForeignKeyConstraints() + public function supportsForeignKeyConstraints() : bool { return false; } @@ -765,7 +754,7 @@ public function supportsForeignKeyConstraints() /** * {@inheritDoc} */ - public function getCreatePrimaryKeySQL(Index $index, $table) + public function getCreatePrimaryKeySQL(Index $index, $table) : string { throw new DBALException('Sqlite platform does not support alter primary key.'); } @@ -773,7 +762,7 @@ public function getCreatePrimaryKeySQL(Index $index, $table) /** * {@inheritdoc} */ - public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) + public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) : string { throw new DBALException('Sqlite platform does not support alter foreign key.'); } @@ -781,7 +770,7 @@ public function getCreateForeignKeySQL(ForeignKeyConstraint $foreignKey, $table) /** * {@inheritdoc} */ - public function getDropForeignKeySQL($foreignKey, $table) + public function getDropForeignKeySQL($foreignKey, $table) : string { throw new DBALException('Sqlite platform does not support alter foreign key.'); } @@ -789,7 +778,7 @@ public function getDropForeignKeySQL($foreignKey, $table) /** * {@inheritDoc} */ - public function getCreateConstraintSQL(Constraint $constraint, $table) + public function getCreateConstraintSQL(Constraint $constraint, $table) : string { throw new DBALException('Sqlite platform does not support alter constraint.'); } @@ -797,17 +786,15 @@ public function getCreateConstraintSQL(Constraint $constraint, $table) /** * {@inheritDoc} */ - public function getCreateTableSQL(Table $table, $createFlags = null) + public function getCreateTableSQL(Table $table, int $createFlags = self::CREATE_INDEXES | self::CREATE_FOREIGNKEYS) : array { - $createFlags = $createFlags ?? self::CREATE_INDEXES | self::CREATE_FOREIGNKEYS; - return parent::getCreateTableSQL($table, $createFlags); } /** * {@inheritDoc} */ - public function getListTableForeignKeysSQL($table, $database = null) + public function getListTableForeignKeysSQL(string $table, ?string $database = null) : string { $table = str_replace('.', '__', $table); @@ -817,7 +804,7 @@ public function getListTableForeignKeysSQL($table, $database = null) /** * {@inheritDoc} */ - public function getAlterTableSQL(TableDiff $diff) + public function getAlterTableSQL(TableDiff $diff) : array { $sql = $this->getSimpleAlterTableSQL($diff); if ($sql !== false) { @@ -1018,7 +1005,7 @@ private function getSimpleAlterTableSQL(TableDiff $diff) /** * @return string[] */ - private function getColumnNamesInAlteredTable(TableDiff $diff) + private function getColumnNamesInAlteredTable(TableDiff $diff) : array { $columns = []; @@ -1058,7 +1045,7 @@ private function getColumnNamesInAlteredTable(TableDiff $diff) /** * @return Index[] */ - private function getIndexesInAlteredTable(TableDiff $diff) + private function getIndexesInAlteredTable(TableDiff $diff) : array { $indexes = $diff->fromTable->getIndexes(); $columnNames = $this->getColumnNamesInAlteredTable($diff); @@ -1097,18 +1084,20 @@ private function getIndexesInAlteredTable(TableDiff $diff) } foreach ($diff->removedIndexes as $index) { - $indexName = strtolower($index->getName()); - if (! strlen($indexName) || ! isset($indexes[$indexName])) { + $indexName = $index->getName(); + + if ($indexName === '') { continue; } - unset($indexes[$indexName]); + unset($indexes[strtolower($indexName)]); } foreach (array_merge($diff->changedIndexes, $diff->addedIndexes, $diff->renamedIndexes) as $index) { - $indexName = strtolower($index->getName()); - if (strlen($indexName)) { - $indexes[$indexName] = $index; + $indexName = $index->getName(); + + if ($indexName !== '') { + $indexes[strtolower($indexName)] = $index; } else { $indexes[] = $index; } @@ -1120,7 +1109,7 @@ private function getIndexesInAlteredTable(TableDiff $diff) /** * @return ForeignKeyConstraint[] */ - private function getForeignKeysInAlteredTable(TableDiff $diff) + private function getForeignKeysInAlteredTable(TableDiff $diff) : array { $foreignKeys = $diff->fromTable->getForeignKeys(); $columnNames = $this->getColumnNamesInAlteredTable($diff); @@ -1155,18 +1144,20 @@ private function getForeignKeysInAlteredTable(TableDiff $diff) $constraint = new Identifier($constraint); } - $constraintName = strtolower($constraint->getName()); - if (! strlen($constraintName) || ! isset($foreignKeys[$constraintName])) { + $constraintName = $constraint->getName(); + + if ($constraintName === '') { continue; } - unset($foreignKeys[$constraintName]); + unset($foreignKeys[strtolower($constraintName)]); } foreach (array_merge($diff->changedForeignKeys, $diff->addedForeignKeys) as $constraint) { - $constraintName = strtolower($constraint->getName()); - if (strlen($constraintName)) { - $foreignKeys[$constraintName] = $constraint; + $constraintName = $constraint->getName(); + + if ($constraintName !== '') { + $foreignKeys[strtolower($constraintName)] = $constraint; } else { $foreignKeys[] = $constraint; } @@ -1178,7 +1169,7 @@ private function getForeignKeysInAlteredTable(TableDiff $diff) /** * @return Index[] */ - private function getPrimaryIndexInAlteredTable(TableDiff $diff) + private function getPrimaryIndexInAlteredTable(TableDiff $diff) : array { $primaryIndex = []; diff --git a/tests/Doctrine/Tests/DBAL/Functional/Driver/PDOSqlite/DriverTest.php b/tests/Doctrine/Tests/DBAL/Functional/Driver/PDOSqlite/DriverTest.php index 8d354ed5fb0..a7a6fe6e36d 100644 --- a/tests/Doctrine/Tests/DBAL/Functional/Driver/PDOSqlite/DriverTest.php +++ b/tests/Doctrine/Tests/DBAL/Functional/Driver/PDOSqlite/DriverTest.php @@ -26,6 +26,14 @@ protected function setUp() : void $this->markTestSkipped('pdo_sqlite only test.'); } + /** + * {@inheritdoc} + */ + public function testReturnsDatabaseNameWithoutDatabaseNameParameter() : void + { + $this->markTestSkipped('SQLite does not support the concept of a database.'); + } + /** * {@inheritdoc} */ diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php index 5ec91537a24..3753a8e779e 100644 --- a/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php +++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php @@ -1062,12 +1062,9 @@ public function testColumnDefaultLifecycle() : void $table = new Table('col_def_lifecycle'); $table->addColumn('id', 'integer', ['autoincrement' => true]); $table->addColumn('column1', 'string', ['default' => null]); - $table->addColumn('column2', 'string', ['default' => false]); - $table->addColumn('column3', 'string', ['default' => true]); - $table->addColumn('column4', 'string', ['default' => 0]); - $table->addColumn('column5', 'string', ['default' => '']); - $table->addColumn('column6', 'string', ['default' => 'def']); - $table->addColumn('column7', 'integer', ['default' => 0]); + $table->addColumn('column2', 'string', ['default' => '']); + $table->addColumn('column3', 'string', ['default' => 'default1']); + $table->addColumn('column4', 'integer', ['default' => 0]); $table->setPrimaryKey(['id']); $this->schemaManager->dropAndCreateTable($table); @@ -1077,21 +1074,15 @@ public function testColumnDefaultLifecycle() : void self::assertNull($columns['id']->getDefault()); self::assertNull($columns['column1']->getDefault()); self::assertSame('', $columns['column2']->getDefault()); - self::assertSame('1', $columns['column3']->getDefault()); + self::assertSame('default1', $columns['column3']->getDefault()); self::assertSame('0', $columns['column4']->getDefault()); - self::assertSame('', $columns['column5']->getDefault()); - self::assertSame('def', $columns['column6']->getDefault()); - self::assertSame('0', $columns['column7']->getDefault()); $diffTable = clone $table; - $diffTable->changeColumn('column1', ['default' => false]); + $diffTable->changeColumn('column1', ['default' => '']); $diffTable->changeColumn('column2', ['default' => null]); - $diffTable->changeColumn('column3', ['default' => false]); + $diffTable->changeColumn('column3', ['default' => 'default2']); $diffTable->changeColumn('column4', ['default' => null]); - $diffTable->changeColumn('column5', ['default' => false]); - $diffTable->changeColumn('column6', ['default' => 666]); - $diffTable->changeColumn('column7', ['default' => null]); $comparator = new Comparator(); @@ -1101,11 +1092,8 @@ public function testColumnDefaultLifecycle() : void self::assertSame('', $columns['column1']->getDefault()); self::assertNull($columns['column2']->getDefault()); - self::assertSame('', $columns['column3']->getDefault()); + self::assertSame('default2', $columns['column3']->getDefault()); self::assertNull($columns['column4']->getDefault()); - self::assertSame('', $columns['column5']->getDefault()); - self::assertSame('666', $columns['column6']->getDefault()); - self::assertNull($columns['column7']->getDefault()); } public function testListTableWithBinary() : void diff --git a/tests/Doctrine/Tests/DBAL/Platforms/AbstractPlatformTestCase.php b/tests/Doctrine/Tests/DBAL/Platforms/AbstractPlatformTestCase.php index 9ba935c2e9d..d46d9e6d0da 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/AbstractPlatformTestCase.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/AbstractPlatformTestCase.php @@ -246,10 +246,10 @@ public function testGeneratesPartialIndexesSqlOnlyWhenSupportingPartialIndexes() public function testGeneratesForeignKeyCreationSql() : void { - $fk = new ForeignKeyConstraint(['fk_name_id'], 'other_table', ['id'], ''); + $fk = new ForeignKeyConstraint(['fk_name_id'], 'other_table', ['id']); $sql = $this->platform->getCreateForeignKeySQL($fk, 'test'); - self::assertEquals($sql, $this->getGenerateForeignKeySql()); + self::assertEquals($this->getGenerateForeignKeySql(), $sql); } abstract public function getGenerateForeignKeySql() : string; diff --git a/tests/Doctrine/Tests/DBAL/Platforms/AbstractSQLServerPlatformTestCase.php b/tests/Doctrine/Tests/DBAL/Platforms/AbstractSQLServerPlatformTestCase.php index 0b8e554300d..a7e42301821 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/AbstractSQLServerPlatformTestCase.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/AbstractSQLServerPlatformTestCase.php @@ -1032,9 +1032,9 @@ public function testChangeColumnsTypeWithDefaultValue() : void $tableDiff->changedColumns['col_string'] = new ColumnDiff( 'col_string', - new Column('col_string', Type::getType('string'), ['default' => 666, 'fixed' => true]), + new Column('col_string', Type::getType('string'), ['default' => 'foo', 'fixed' => true]), ['fixed'], - new Column('col_string', Type::getType('string'), ['default' => 666]) + new Column('col_string', Type::getType('string'), ['default' => 'foo']) ); $expected = $this->platform->getAlterTableSQL($tableDiff); @@ -1047,7 +1047,7 @@ public function testChangeColumnsTypeWithDefaultValue() : void 'ALTER TABLE column_def_change_type ADD CONSTRAINT DF_829302E0_FA2CB292 DEFAULT 666 FOR col_int', 'ALTER TABLE column_def_change_type DROP CONSTRAINT DF_829302E0_2725A6D0', 'ALTER TABLE column_def_change_type ALTER COLUMN col_string NCHAR(255) NOT NULL', - "ALTER TABLE column_def_change_type ADD CONSTRAINT DF_829302E0_2725A6D0 DEFAULT '666' FOR col_string", + "ALTER TABLE column_def_change_type ADD CONSTRAINT DF_829302E0_2725A6D0 DEFAULT 'foo' FOR col_string", ] ); } diff --git a/tests/Doctrine/Tests/DBAL/Platforms/SQLAnywherePlatformTest.php b/tests/Doctrine/Tests/DBAL/Platforms/SQLAnywherePlatformTest.php index b3b1d48621f..506d9358ad0 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/SQLAnywherePlatformTest.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/SQLAnywherePlatformTest.php @@ -253,8 +253,6 @@ public static function getLockHints() : iterable { return [ [null, ''], - [false, ''], - [true, ''], [LockMode::NONE, ' WITH (NOLOCK)'], [LockMode::OPTIMISTIC, ''], [LockMode::PESSIMISTIC_READ, ' WITH (UPDLOCK)'], @@ -757,13 +755,6 @@ public function testGeneratesTransactionsCommands() : void ); } - public function testCannotGenerateTransactionCommandWithInvalidIsolationLevel() : void - { - $this->expectException(InvalidArgumentException::class); - - $this->platform->getSetTransactionIsolationSQL('invalid_transaction_isolation_level'); - } - public function testModifiesLimitQuery() : void { self::assertEquals( @@ -916,10 +907,6 @@ public function testGeneratesSequenceSqlCommands() : void 'SELECT myseq.NEXTVAL', $this->platform->getSequenceNextValSQL('myseq') ); - self::assertEquals( - 'SELECT sequence_name, increment_by, start_with, min_value FROM SYS.SYSSEQUENCE', - $this->platform->getListSequencesSQL(null) - ); } public function testDoesNotSupportInlineColumnComments() : void diff --git a/tests/Doctrine/Tests/DBAL/Platforms/SQLServerPlatformTest.php b/tests/Doctrine/Tests/DBAL/Platforms/SQLServerPlatformTest.php index 98cbf2b1570..f6156d394de 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/SQLServerPlatformTest.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/SQLServerPlatformTest.php @@ -45,8 +45,6 @@ public static function getLockHints() : iterable { return [ [null, ''], - [false, ''], - [true, ''], [LockMode::NONE, ' WITH (NOLOCK)'], [LockMode::OPTIMISTIC, ''], [LockMode::PESSIMISTIC_READ, ' WITH (HOLDLOCK, ROWLOCK)'], diff --git a/tests/Doctrine/Tests/DBAL/Platforms/SqlitePlatformTest.php b/tests/Doctrine/Tests/DBAL/Platforms/SqlitePlatformTest.php index 7d96bcbbb8a..f799f7ff5fd 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/SqlitePlatformTest.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/SqlitePlatformTest.php @@ -688,7 +688,7 @@ protected static function getInlineColumnCommentRequiringEscapingSQL() : string protected static function getInlineColumnEmptyCommentSQL() : string { - return "--\n"; + return ''; } /**