在 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 '主题商店的主题版本的语义化'"); }
近期评论