在 Laravel 6 的数据库迁移中,更新字段属性时,Doctrine\DBAL\Exception : Unknown database type enum requested, Doctrine\DBAL\Platforms\MySQL57Platform may not support it.
1、Doctrine\DBAL\Exception : Unknown database type enum requested, Doctrine\DBAL\Platforms\MySQL57Platform may not support it.。如图1
PS E:\wwwroot\object> php artisan module:migrate ThemeStoreDB
Migrating: 2022_12_08_173303_alter_theme_store_theme_version_semantic_on_theme_installation_version_preset_table
Doctrine\DBAL\Exception : Unknown database type enum requested, Doctrine\DBAL\Platforms\MySQL57Platform may not support it.
at E:\wwwroot\object\vendor\doctrine\dbal\lib\Doctrine\DBAL\Platforms\AbstractPlatform.php:454
450|
451| $dbType = strtolower($dbType);
452|
453| if (! isset($this->doctrineTypeMapping[$dbType])) {
> 454| throw new Exception(
455| 'Unknown database type ' . $dbType . ' requested, ' . static::class . ' may not support it.'
456| );
457| }
458|
Exception trace:
1 Doctrine\DBAL\Platforms\AbstractPlatform::getDoctrineTypeMapping("enum")
E:\wwwroot\object\vendor\doctrine\dbal\lib\Doctrine\DBAL\Schema\MySqlSchemaManager.php:134
2 Doctrine\DBAL\Schema\MySqlSchemaManager::_getPortableTableColumnDefinition()
E:\wwwroot\object\vendor\doctrine\dbal\lib\Doctrine\DBAL\Schema\AbstractSchemaManager.php:820
Please use the argument -v to see more details.
2、查看迁移文件,更新的字段类型中并不存在 enum
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::table('theme_installation_version_preset', function (Blueprint $table) {
$table->string('theme_store_theme_version_semantic', 64)->comment('主题商店的主题版本的语义化')->change();
});
}
3、最后确定原因,可能在于此迁移文件所涉及的表中,其他字段的类型为 enum。如图2
4、参考:https://www.shuijingwanwq.com/2022/06/02/6483/ ,使用 DB::statement。执行迁移成功。如图3
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
$fullTableName = DB::connection()->getTablePrefix() . 'theme_installation_version_preset';
DB::statement("ALTER TABLE $fullTableName modify theme_store_theme_version_semantic varchar(64) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '主题商店的主题版本的语义化'");
}



近期评论