From 353ed1544a98e043f9d58fc626bfd2b821449809 Mon Sep 17 00:00:00 2001 From: Alex Miles Date: Fri, 25 Oct 2024 14:58:53 +0100 Subject: [PATCH] Add upgrade note for changed migration behaviour --- upgrade.md | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/upgrade.md b/upgrade.md index 0c1008e39d..9f65c0da06 100644 --- a/upgrade.md +++ b/upgrade.md @@ -34,6 +34,7 @@
- [Doctrine DBAL Removal](#doctrine-dbal-removal) +- [Renaming And Adding Columns](#renaming-and-adding-columns) - [Eloquent Model `casts` Method](#eloquent-model-casts-method) - [Spatial Types](#spatial-types) - [The `Enumerable` Contract](#the-enumerable-contract) @@ -277,6 +278,31 @@ php artisan schema:dump Once your migrations have been squashed, Laravel will "migrate" the database using your application's schema file before running any pending migrations. + +#### Renaming And Adding Columns + +**Likelihood Of Impact: Low** + +When renaming a column and adding a new column after the renamed column, using the `after()` modifier, changes are required because the order of operations performed by `Schema::table()` has changed. + +For example, imagine you have a migration that renames a `votes` column, and then adds a `description` column: + +```php +Schema::table('users', function (Blueprint $table) { + $table->string('description')->after('votes'); + $table->renameColumn('votes', 'vote_count'); +}); +``` + +In Laravel 10, this works as expected. However, in Laravel 11, this causes an error because the renaming operation occurs first. Instead, the `after()` modifier must now refer to the new column name: + +```php +Schema::table('users', function (Blueprint $table) { + $table->renameColumn('votes', 'vote_count'); + $table->string('description')->after('vote_count'); +}); +``` + #### Floating-Point Types