Adding New Column to an existing table
In this article, you will learn the step-by-step procedure to add single or multiple columns in our existing database tables using Laravel migration.
Step 1: To get started, open the command prompt or terminal and navigate to the root directory of our Laravel project.
data:image/s3,"s3://crabby-images/830f9/830f9520f59035638d85cb3172046a3245e59604" alt=""
Step 2: Type the following command to create a new migration file:
php artisan make:migration add_phone_number_to_schools |
This code will create an add_type_to_notes file in the migration folder. it will look like this-
data:image/s3,"s3://crabby-images/3e5ae/3e5ae7718df6e1ac6fb839dbdf1b435e88859d14" alt=""
Now, replace the column_name with the name of the column you want to add and the table_name with the name of the table you want to modify.
Step 3: Open the newly created migration file in the database/migrations folder. Inside the up function, add the code to create the new column or columns:
<?php
use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration;
class AddPhoneNumberToSchools extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::table('schools', function (Blueprint $table) { $table->string('phone_number', 10)->nullable(false)->default(null); }); }
/** * Reverse the migrations. * * @return void */ public function down() { Schema::table('schools', function (Blueprint $table) { $table->dropColumn('phone_number'); }); } } |
Step 4: Run the migration command.
Initially, our screen will look like the below image.
data:image/s3,"s3://crabby-images/9f85a/9f85a2040fb5eb7955fd5b2f8facab794d09db85" alt=""
As soon as we run the migration command a new column will be added and our database will look like the below image.
data:image/s3,"s3://crabby-images/0be23/0be23ebe37e016f51cbdc25e25dae6fa24302810" alt=""
To make our database look like the above image and add a new column, we have to add the below code to our database.
php artisan migrate C:\xampp\htdocs\laraveltest>php artisan migrate Migrating: 2023_05_01_055549_add_phone_number_to_schools Migrated: 2023_05_01_055549_add_phone_number_to_schools (21.14ms) C:\xampp\htdocs\laraveltest> |
Adding Multiple Columns to an Existing Table using Laravel Migration
To add multiple columns to the existing table
Step 1: Navigate to the root directory and enter the following command
php artisan make:migration add_multiple_column_to_schools |
Step 2: As we want to add multiple columns to the existing table, we have to introduce the column name in our code.
Use the below command to introduce new column names.
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class School extends Model { protected $fillable = [ 'school_name', 'email', 'country', 'phone_number', 'Afiliated_by', 'School_location', 'Medium' ]; }
|
Step 3: Adding code to the newly added migration file.
<?php
use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration;
class AddMultipleColumnToSchools extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::table('schools', function (Blueprint $table) { $table->string('afiliated_by')->nullable(); $table->string('short_description')->nullable(); $table->string('medium')->nullable() }); }
/** * Reverse the migrations. * * @return void */ public function down() { Schema::table('schools', function (Blueprint $table) { $table->dropColumn(['afiliated_by', 'short_description', 'medium']); }); } }
|
Step 4: Run the below command and check the database:
data:image/s3,"s3://crabby-images/6771d/6771d8df4f88445a53c72dd6d2e4c07a604b479a" alt=""
The final image shows that we have successfully added multiple columns in the existing table using Laravel migration.
No comments:
Post a Comment