我想要的

仅回退:

回滚:2015_05_15_195423_alter_table_web_directories


我跑

PHP artisan migrate:rollback,我的3个迁移都在回滚。

Rolled back: 2015_05_15_195423_alter_table_web_directories
Rolled back: 2015_05_13_135240_create_web_directories_table
Rolled back: 2015_05_13_134411_create_contacts_table

我删除

我的web_directory和我的联系人表都是无意的。我不希望发生这种情况,如果我只能回滚特定的一个,这种灾难就永远不会发生。


当前回答

除此之外

php artisan migrate:rollback --step=1

我将添加一个检查表迁移:

select * from migrations;

这将显示一个有序的列表,其中包含artisan命令回滚的迁移。

其他回答

除此之外

php artisan migrate:rollback --step=1

我将添加一个检查表迁移:

select * from migrations;

这将显示一个有序的列表,其中包含artisan命令回滚的迁移。

拉拉维尔 5.3+

回退一步。本机。

php artisan migrate:rollback --step=1

这是手册页:文档。


Laravel 5.2及之前版本

不麻烦就没办法。详情请看Martin Bean的回答。

如果你不能做到@Martin Bean告诉你的,那么你可以尝试另一个技巧。

创建一个新的迁移,在该文件上,在up()方法中插入你想要回滚的迁移的down()方法中的内容,在down()方法中插入up()方法中的内容。

例如,如果你最初的迁移是这样的

public function up()
{
    Schema::create('users', function(Blueprint $table)
    {
        $table->increments('id')->unsigned();
        $table->string('name');
    });
}
public function down()
{
    Schema::drop('users');
}

然后在新的迁移文件中这样做

public function up()
{
    Schema::drop('users');
}
public function down()
{
    Schema::create('users', function(Blueprint $table)
    {
        $table->increments('id')->unsigned();
        $table->string('name');
    });
}

然后运行migrate,它会删除这个表。 如果你想要回滚它。

你可以使用

php artisan migrate:rollback --path=/database/migrations/timestamp_filename.php

这将删除特定的迁移。如果文件有外键依赖,我希望你使用drop方法。对于这些情况,请尝试创建一个新的迁移,并在需要时删除foreign。

试试这个:

php artisan migrate:rollback --step=1

这是从Laravel 5.3 +工作