How to Use an Enum In A Laravel Migration?

13 minutes read

To use an enum in a Laravel migration, you can follow these steps:

  1. Create a new migration: Use the make:migration Artisan command to generate a new migration file. For example, php artisan make:migration create_users_table.
  2. Open the migration file: Locate the newly created migration file inside the database/migrations directory and open it.
  3. Add the enum field: Inside the migration's up method, use the addColumn function on the Schema facade to add the enum field. The addColumn method accepts the table name, field name, field type, and optional parameters. For an enum, use the enum type and provide the allowed values as an array. For instance, if you want to add an enum field named status in a users table with the values 'active', 'inactive', and 'pending', you can write: Schema::table('users', function (Blueprint $table) { $table->enum('status', ['active', 'inactive', 'pending']); });
  4. Run the migration: Save the file and execute the migration using the migrate command: php artisan migrate.


That's it! The enum field will be added to your database table. Remember to update the migration's down method with the corresponding dropColumn command if you want to rollback the migration.

Best Laravel Cloud Hosting Providers of January 2025

1
DigitalOcean

Rating is 5 out of 5

DigitalOcean

2
AWS

Rating is 4.9 out of 5

AWS

3
Vultr

Rating is 4.8 out of 5

Vultr

4
Cloudways

Rating is 4.7 out of 5

Cloudways


What is the purpose of using an enum in a migration?

The purpose of using an enum in a migration is to define a set of possible values for a particular column in a database table.


When creating or modifying a table in a database, you may want to restrict the values that can be stored in a specific column. Using an enum allows you to define a list of allowed values for that column, ensuring that only those values can be inserted or updated in the database.


This helps enforce data integrity and validity, as it prevents invalid or unexpected values from being stored in the database. It also provides an easy way to understand and interpret the data within that column, as the possible values are explicitly defined.


For example, if you have a "gender" column in a "users" table, you can use an enum to define that the possible values are "male" and "female". This prevents any other values like "unknown" or misspelled versions from being stored in the database.


Can you alter the values of an existing enum column in a Laravel migration?

No, you cannot directly alter the values of an existing enum column in a Laravel migration.


In MySQL, altering the values of an enum column is not directly supported. To modify the values of an enum column, you'll need to follow these steps manually:

  1. Create a new migration using the php artisan make:migration command.
  2. In the up() method of the new migration, rename the existing column to a temporary name using the renameColumn method:
1
2
3
Schema::table('your_table', function ($table) {
    $table->renameColumn('your_column', 'temporary_column');
});


  1. After renaming the column, add a new column with the same name and desired enum values using the addColumn method:
1
2
3
Schema::table('your_table', function ($table) {
    $table->enum('your_column', ['new_value1', 'new_value2', ...])->default('new_value1');
});


  1. If necessary, update any other part of your codebase to reflect the changes in your enum values.
  2. Finally, in the down() method of the migration, reverse the process by renaming and removing the temporary column:
1
2
3
4
Schema::table('your_table', function ($table) {
    $table->renameColumn('temporary_column', 'your_column');
    $table->dropColumn('temporary_column');
});


  1. Run the migration using the php artisan migrate command.


Note that this method uses column renaming and creation, so be cautious about any data loss or dependencies that might be impacted.


Can an enum have multiple values in a Laravel migration?

No, an enum column in Laravel migration can only have a single value at a time.


Enums are used to define a column that can only have a specific set of values. Each value in the enum is treated as a separate option, and you can choose one of them at a time to assign to the column.


Here's an example of how to create an enum column in a Laravel migration:

1
2
3
4
5
6
public function up()
{
    Schema::create('example_table', function (Blueprint $table) {
        $table->enum('status', ['active', 'inactive', 'deleted']);
    });
}


In the example above, the 'status' column can only have one of the three values: 'active', 'inactive', or 'deleted'.

Top Rated Laravel Books of January 2025

1
Laravel: Up and Running: A Framework for Building Modern PHP Apps

Rating is 5 out of 5

Laravel: Up and Running: A Framework for Building Modern PHP Apps

2
Battle Ready Laravel: A guide to auditing, testing, fixing, and improving your Laravel applications

Rating is 4.9 out of 5

Battle Ready Laravel: A guide to auditing, testing, fixing, and improving your Laravel applications

3
Laravel: Up & Running: A Framework for Building Modern PHP Apps

Rating is 4.8 out of 5

Laravel: Up & Running: A Framework for Building Modern PHP Apps

4
High Performance with Laravel Octane: Learn to fine-tune and optimize PHP and Laravel apps using Octane and an asynchronous approach

Rating is 4.7 out of 5

High Performance with Laravel Octane: Learn to fine-tune and optimize PHP and Laravel apps using Octane and an asynchronous approach

5
Beginning Laravel: Build Websites with Laravel 5.8

Rating is 4.6 out of 5

Beginning Laravel: Build Websites with Laravel 5.8

6
Murach's PHP and MySQL (4th Edition)

Rating is 4.5 out of 5

Murach's PHP and MySQL (4th Edition)

7
PHP & MySQL: Server-side Web Development

Rating is 4.4 out of 5

PHP & MySQL: Server-side Web Development


How do you rename an enum column in a Laravel migration?

To rename an enum column in a Laravel migration, you can follow these steps:

  1. Open the migration file that contains the column you want to rename.
  2. Locate the up() method, which defines the changes you want to make to the database schema.
  3. Inside the up() method, use the table method to create a new temporary column with a different name. For example, if you want to rename a column named status to new_status, you can use the following code:
1
2
3
Schema::table('your_table', function ($table) {
    $table->enum('new_status', ['value1', 'value2', 'value3'])->nullable();
});


  1. Next, use the update() method to update the values of the newly created column based on the old column's values. You can use the DB::raw() method to execute an SQL query to copy the values. For example:
1
DB::statement('UPDATE your_table SET new_status = status');


  1. After updating the values, remove the old column using the dropColumn() method. For example:
1
2
3
Schema::table('your_table', function ($table) {
    $table->dropColumn('status');
});


  1. Finally, rename the new column to the desired name using the renameColumn() method. For example, to rename the new_status column to status, use:
1
2
3
Schema::table('your_table', function ($table) {
    $table->renameColumn('new_status', 'status');
});


Once you have made the necessary changes, save the file and run your migration using the php artisan migrate command. The column will be renamed in your database schema.


What is an enum in PHP?

In PHP, an enum is a special data type that represents a fixed set of constants. It allows you to define a set of named values that can be used as discreet options within your code. Enums are useful when you want to limit the possible values of a variable and provide readable names for those values.


PHP doesn't have a built-in enum type like some other programming languages. However, you can achieve similar functionality by using class constants. Here's an example of defining an enum-like structure in PHP:

1
2
3
4
5
6
7
class Color {
    const RED = 1;
    const GREEN = 2;
    const BLUE = 3;
}

$color = Color::RED;


In the above example, the Color class defines three constants (RED, GREEN, and BLUE) representing different colors. You can access these constants using the class name, followed by ::. Assigning the value of Color::RED to the $color variable sets it to the RED value of the enum.


Enums in PHP can be used to improve code readability and prevent using invalid values. However, they lack some of the advanced features of enums in other languages, such as automatically assigning ordinal values or iterating over all possible values.


Can you use an enum column in a Laravel migration as part of a composite key?

Yes, you can use an enum column as part of a composite key in a Laravel migration. Here is an example of how you can define a composite key with an enum column:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateUsersTable extends Migration
{
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->id();
            $table->enum('status', ['active', 'inactive']);
            $table->string('email')->unique();
            // Add your other columns here

            // Set the enum column as part of the composite key
            $table->primary(['status', 'email']);
        });
    }

    public function down()
    {
        Schema::dropIfExists('users');
    }
}


In this example, the status column is defined as an enum column with two possible values: active and inactive. The email column is also defined as a string column.


The primary() method is used to define the composite key, passing an array of column names as arguments. In this case, ['status', 'email'] is used to create a composite key using both the status and email columns.


Remember to adjust the code according to your specific migration needs.


Can you use an enum column in a Laravel migration as part of an index?

Yes, you can use an enum column in a Laravel migration as part of an index. Here's an example:

1
2
3
4
5
6
7
8
public function up()
{
    Schema::create('users', function (Blueprint $table) {
        $table->id();
        $table->enum('status', ['active', 'inactive'])->index(); // Enum column with an index
        $table->timestamps();
    });
}


In the above example, the status column is defined as an enum column with values 'active' and 'inactive'. The index() method is then chained to the column definition to create an index on that column.


Remember to run php artisan migrate command after creating the migration file to apply the changes to the database.

Facebook Twitter LinkedIn Telegram

Related Posts:

To execute a DDL migration script in Laravel, you can create a new migration file using the artisan command php artisan make:migration. In this migration file, you can define the schema changes you want to make to your database using Laravel's schema build...
To drop columns in Laravel migration, you need to follow these steps:Open your terminal and navigate to your Laravel project. Generate a migration file using the make:migration artisan command. For example, let's say you want to drop a column named email f...
To add a foreign key in Laravel migration, you need to follow these steps:Firstly, create a new migration using the make:migration Artisan command. For example, run php artisan make:migration add_foreign_key_to_table --table=table_name in the terminal. Open th...