为了账号安全,请及时绑定邮箱和手机立即绑定

RollbackCommand.php

标签:
PHP

<?php

 

namespace Illuminate\Database\Console\Migrations;

 

use Illuminate\Console\Command;

use Illuminate\Console\ConfirmableTrait;

use Illuminate\Database\Migrations\Migrator;

use Symfony\Component\Console\Input\InputOption;

 

class RollbackCommand extends Command

{

    use ConfirmableTrait;

 

    /**

     * The console command name.

     *

     * @var string

     */

    protected $name = 'migrate:rollback';

 

    /**

     * The console command description.

     *

     * @var string

     */

    protected $description = 'Rollback the last database migration';

 

    /**

     * The migrator instance.

     *

     * @var \Illuminate\Database\Migrations\Migrator

     */

    protected $migrator;

 

    /**

     * Create a new migration rollback command instance.

     *

     * @param  \Illuminate\Database\Migrations\Migrator  $migrator

     * @return void

     */

    public function __construct(Migrator $migrator)

    {

        parent::__construct();

 

        $this->migrator = $migrator;

    }

 

    /**

     * Execute the console command.

     *

     * @return void

     */

    public function fire()

    {

        if (! $this->confirmToProceed()) {

            return;

        }

 

        $this->migrator->setConnection($this->input->getOption('database'));

 

        $pretend = $this->input->getOption('pretend');

 

        $this->migrator->rollback($pretend);

 

        // Once the migrator has run we will grab the note output and send it out to

        // the console screen, since the migrator itself functions without having

        // any instances of the OutputInterface contract passed into the class.

        foreach ($this->migrator->getNotes() as $note) {

            $this->output->writeln($note);

        }

    }

 

    /**

     * Get the console command options.

     *

     * @return array

     */

    protected function getOptions()

    {

        return [

            ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],

 

            ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'],

 

            ['pretend', null, InputOption::VALUE_NONE, 'Dump the SQL queries that would be run.'],

        ];

    }

}//same

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消