Laravel在迁移中向现有表添加新列

2022-02-19 00:00:00 php laravel laravel-migrations

我不知道如何使用Laravel框架向现有数据库表添加新列。

我尝试使用.

编辑迁移文件
<?php

public function up()
{
    Schema::create('users', function ($table) {
        $table->integer("paid");
    });
}

在终端执行php artisan migrate:installmigrate

如何添加新列?


解决方案

若要创建迁移,可以在Artisan CLI上使用Migrate:Make命令。使用特定名称以避免与现有模型冲突

对于Laravel 5+:

php artisan make:migration add_paid_to_users_table --table=users

对于Laravel 3:

php artisan migrate:make add_paid_to_users
然后需要使用Schema::table()方法(因为您正在访问现有表,而不是创建新表)。您可以添加如下所示的列:

public function up()
{
    Schema::table('users', function($table) {
        $table->integer('paid');
    });
}

别忘了添加回滚选项:

public function down()
{
    Schema::table('users', function($table) {
        $table->dropColumn('paid');
    });
}

然后您可以运行迁移:

php artisan migrate

这在Laravel 4/Laravel 5的文档中都有很好的介绍:

  • Schema Builder
  • Migrations

对于Laravel 3:

  • Schema Builder
  • Migrations

编辑:

使用$table->integer('paid')->after('whichever_column');将此字段添加到特定列之后。

相关文章