<?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 ResetCommand extends Command {//Reset Command extends Command use ConfirmableTrait;//same /** * The console command name. * * @var string */ protected $name = 'migrate:reset';//same /** * The console command description. * * @var string */ protected $description = 'Rollback all database migrations';//same /** * The migrator instance. * * @var \Illuminate\Database\Migrations\Migrator */ protected $migrator;//same /** * 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; }//same /** * Execute the console command. * * @return void */ public function fire() { if (! $this->confirmToProceed()) { return; } $this->migrator->setConnection($this->input->getOption('database')); if (! $this->migrator->repositoryExists()) { $this->output->writeln('<comment>Migration table not found.</comment>'); return; } $pretend = $this->input->getOption('pretend'); $this->migrator->reset($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); } }//same /** * 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 }
[李景山php]每天laravel-20161123|ResetCommand.php
原创
©著作权归作者所有:来自51CTO博客作者lijingsan1的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章