Compare commits

..

2 commits

Author SHA1 Message Date
rxu
b210198852
[ticket/17528] Fix PostgreSQL platform issues
PHPBB-17528
2025-06-20 15:26:57 +07:00
rxu
389a813cdf
[ticket/17528] Fix MySQL platform
PHPBB-17528
2025-06-20 14:51:17 +07:00
3 changed files with 70 additions and 6 deletions

View file

@ -149,6 +149,7 @@ class connection_parameter_factory
$enrichment_tags = [ $enrichment_tags = [
'pdo_mysql' => [ 'pdo_mysql' => [
'charset' => 'UTF8', 'charset' => 'UTF8',
'platform' => new mysql_platform(),
], ],
'oci8' => [ 'oci8' => [
'charset' => 'UTF8', 'charset' => 'UTF8',

View file

@ -0,0 +1,62 @@
<?php
/**
*
* This file is part of the phpBB Forum Software package.
*
* @copyright (c) phpBB Limited <https://www.phpbb.com>
* @license GNU General Public License, version 2 (GPL-2.0)
*
* For full copyright and license information, please see
* the docs/CREDITS.txt file.
*
*/
namespace phpbb\db\doctrine;
use Doctrine\DBAL\Platforms\AbstractMySQLPlatform;
use Doctrine\DBAL\Schema\TableDiff;
/**
* MySQL specific schema handling.
*
* While adding auto_increment column to MySQL, it must be indexed.
* If it's indexed as primary key, it ahould be declared as NOT NULL
* because MySQL primary key columns cannot be NULL.
*/
class mysql_platform extends AbstractMySQLPlatform
{
/**
* {@inheritDoc}
*/
public function getAlterTableSQL(TableDiff $diff)
{
$sql = parent::getAlterTableSQL($diff);
$table = $diff->getOldTable();
$columns = $diff->getAddedColumns();
foreach ($columns as $column)
{
$column_name = $column->getName();
if (!empty($column->getAutoincrement()) && $table)
{
foreach ($sql as $i => $query)
{
if (stripos($query, "add $column_name"))
{
if (!$table->getPrimaryKey())
{
$sql[$i] = str_replace(' DEFAULT NULL', '', $sql[$i]);
$sql[$i] .= ' PRIMARY KEY';
}
else
{
$sql[$i] .= ", ADD KEY ($column_name)";
}
}
}
}
}
return $sql;
}
}

View file

@ -18,6 +18,7 @@ use Doctrine\DBAL\Platforms\PostgreSQL94Platform;
use Doctrine\DBAL\Schema\Index; use Doctrine\DBAL\Schema\Index;
use Doctrine\DBAL\Schema\Sequence; use Doctrine\DBAL\Schema\Sequence;
use Doctrine\DBAL\Schema\Table; use Doctrine\DBAL\Schema\Table;
use Doctrine\DBAL\Schema\TableDiff;
use Doctrine\DBAL\Types\BigIntType; use Doctrine\DBAL\Types\BigIntType;
use Doctrine\DBAL\Types\IntegerType; use Doctrine\DBAL\Types\IntegerType;
use Doctrine\DBAL\Types\SmallIntType; use Doctrine\DBAL\Types\SmallIntType;
@ -78,14 +79,14 @@ class postgresql_platform extends PostgreSQL94Platform
return AbstractPlatform::getDefaultValueDeclarationSQL($column); return AbstractPlatform::getDefaultValueDeclarationSQL($column);
} }
/** /**
* {@inheritDoc} * {@inheritDoc}
*/ */
public function getAlterTableSQL(TableDiff $diff) public function getAlterTableSQL(TableDiff $diff)
{ {
$sql = parent::getAlterTableSQL($diff); $sql = parent::getAlterTableSQL($diff);
$table_name = $diff->getOldTable()->getName(); $table_name = $diff->getOldTable()->getName();
$columns = array_merge($diff->getAddedColumns(), $diff->getModifiedColumns()); $columns = $diff->getAddedColumns();
$post_sql = $sequence_sql = []; $post_sql = $sequence_sql = [];
foreach ($columns as $column) foreach ($columns as $column)