diff --git a/docs/en/reference/platforms.rst b/docs/en/reference/platforms.rst index da78e394f22..8827842c4c4 100644 --- a/docs/en/reference/platforms.rst +++ b/docs/en/reference/platforms.rst @@ -34,7 +34,7 @@ MySQL ^^^^^ - ``MySqlPlatform`` for version 5.0 and above. -- ``MySQL57Platform`` for version 5.7 and above. +- ``MySQL57Platform`` for version 5.7 (5.7.9 GA) and above. Oracle ^^^^^^ diff --git a/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php b/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php index dd74a48fa51..86fb00b921a 100644 --- a/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php +++ b/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php @@ -138,10 +138,15 @@ public function createDatabasePlatformForVersion($version) $majorVersion = $versionParts['major']; $minorVersion = isset($versionParts['minor']) ? $versionParts['minor'] : 0; - $patchVersion = isset($versionParts['patch']) ? $versionParts['patch'] : 0; - $version = $majorVersion . '.' . $minorVersion . '.' . $patchVersion; + $patchVersion = isset($versionParts['patch']) ? $versionParts['patch'] : null; - if (version_compare($version, '5.7', '>=')) { + if ('5' === $majorVersion && '7' === $minorVersion && null === $patchVersion) { + $patchVersion = '9'; + } + + $version = $majorVersion . '.' . $minorVersion . '.' . $patchVersion; + + if (version_compare($version, '5.7.9', '>=')) { return new MySQL57Platform(); } diff --git a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php index 7d7b2020877..208677b3ae7 100644 --- a/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php +++ b/lib/Doctrine/DBAL/Platforms/Keywords/MySQL57Keywords.php @@ -119,6 +119,7 @@ protected function getKeywords() 'FOREIGN', 'FROM', 'FULLTEXT', + 'GENERATED', 'GET', 'GRANT', 'GROUP', @@ -183,12 +184,12 @@ protected function getKeywords() 'MODIFIES', 'NATURAL', 'NO_WRITE_TO_BINLOG', - 'NONBLOCKING', 'NOT', 'NULL', 'NUMERIC', 'ON', 'OPTIMIZE', + 'OPTIMIZER_COSTS', 'OPTION', 'OPTIONALLY', 'OR', @@ -241,6 +242,7 @@ protected function getKeywords() 'SSL', 'STARTING', 'STRAIGHT_JOIN', + 'STORED', 'TABLE', 'TERMINATED', 'THEN', @@ -268,6 +270,7 @@ protected function getKeywords() 'VARCHAR', 'VARCHARACTER', 'VARYING', + 'VIRTUAL', 'WHEN', 'WHERE', 'WHILE', diff --git a/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php b/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php index 36b525e2063..8594aa65185 100644 --- a/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php +++ b/lib/Doctrine/DBAL/Platforms/MySQL57Platform.php @@ -23,14 +23,31 @@ use Doctrine\DBAL\Schema\TableDiff; /** - * Provides the behavior, features and SQL dialect of the MySQL 5.7 database platform. + * Provides the behavior, features and SQL dialect of the MySQL 5.7 (5.7.9 GA) database platform. * + * @author İsmail BASKIN * @author Steve Müller * @link www.doctrine-project.org * @since 2.5 */ class MySQL57Platform extends MySqlPlatform { + /** + * {@inheritdoc} + */ + public function hasNativeJsonType() + { + return true; + } + + /** + * {@inheritdoc} + */ + public function getJsonTypeDeclarationSQL(array $field) + { + return 'JSON'; + } + /** * {@inheritdoc} */ @@ -64,4 +81,14 @@ protected function getReservedKeywordsClass() { return 'Doctrine\DBAL\Platforms\Keywords\MySQL57Keywords'; } + + /** + * {@inheritdoc} + */ + protected function initializeDoctrineTypeMappings() + { + parent::initializeDoctrineTypeMappings(); + + $this->doctrineTypeMapping['json'] = 'json_array'; + } } diff --git a/tests/Doctrine/Tests/DBAL/Driver/AbstractMySQLDriverTest.php b/tests/Doctrine/Tests/DBAL/Driver/AbstractMySQLDriverTest.php index 83e15cf9521..25833fcce4b 100644 --- a/tests/Doctrine/Tests/DBAL/Driver/AbstractMySQLDriverTest.php +++ b/tests/Doctrine/Tests/DBAL/Driver/AbstractMySQLDriverTest.php @@ -57,8 +57,10 @@ protected function getDatabasePlatformsForVersions() return array( array('5.6.9', 'Doctrine\DBAL\Platforms\MySqlPlatform'), array('5.7', 'Doctrine\DBAL\Platforms\MySQL57Platform'), - array('5.7.0', 'Doctrine\DBAL\Platforms\MySQL57Platform'), - array('5.7.1', 'Doctrine\DBAL\Platforms\MySQL57Platform'), + array('5.7.0', 'Doctrine\DBAL\Platforms\MySqlPlatform'), + array('5.7.8', 'Doctrine\DBAL\Platforms\MySqlPlatform'), + array('5.7.9', 'Doctrine\DBAL\Platforms\MySQL57Platform'), + array('5.7.10', 'Doctrine\DBAL\Platforms\MySQL57Platform'), array('6', 'Doctrine\DBAL\Platforms\MySQL57Platform'), array('10.0.15-MariaDB-1~wheezy', 'Doctrine\DBAL\Platforms\MySqlPlatform'), array('10.1.2a-MariaDB-a1~lenny-log', 'Doctrine\DBAL\Platforms\MySqlPlatform'), diff --git a/tests/Doctrine/Tests/DBAL/Platforms/MySQL57PlatformTest.php b/tests/Doctrine/Tests/DBAL/Platforms/MySQL57PlatformTest.php index 2fb87070d9a..5e00b12040e 100644 --- a/tests/Doctrine/Tests/DBAL/Platforms/MySQL57PlatformTest.php +++ b/tests/Doctrine/Tests/DBAL/Platforms/MySQL57PlatformTest.php @@ -14,6 +14,22 @@ public function createPlatform() return new MySQL57Platform(); } + public function testHasNativeJsonType() + { + $this->assertTrue($this->_platform->hasNativeJsonType()); + } + + public function testReturnsJsonTypeDeclarationSQL() + { + $this->assertSame('JSON', $this->_platform->getJsonTypeDeclarationSQL(array())); + } + + public function testInitializesJsonTypeMapping() + { + $this->assertTrue($this->_platform->hasDoctrineTypeMappingFor('json')); + $this->assertEquals('json_array', $this->_platform->getDoctrineTypeMapping('json')); + } + /** * @group DBAL-234 */