Symfony2 like database creation command in laravel console?

旧时模样 提交于 2019-12-01 14:45:10

You can do that but you will have to create your own command.

First, run php artisan command:make CreateDatabase --command=database:create to generate app/commands/CreateDatabase.php

Then open that file and change it to this: (I left out all comments, but you can obviously keep them in there)

class CreateDatabase extends Command {
    protected $name = 'database:create';
    protected $description = 'Command description.';

    public function fire()
    {
        DB::statement('CREATE DATABASE '.$this->argument('name'));
    }

    protected function getArguments()
    {
        return array(
            array('name', InputArgument::REQUIRED, 'Database name'),
        );
    }
}

Now you only have to register the command in app/start/artisan.php:

Artisan::add(new CreateDatabase);

and you're good to go.

That's how you call it:

php artisan database:create your-desired-database-name

Alternative: artisan tinker

You can always use php artisan tinker to run PHP code (with Laravel bootstrapped):

php artisan tinker
> DB::statement('CREATE DATABASE your-desired-database-name');

As far as I know, you can use php artisan migrate to make migrations including creating tables from Laravel Console. However, you need to create and modify migration files first, where you can create or drop tables.

So if you want to create a table directly from Laravel Console using something like php artisan create database table ***, it is not possible.

I think you can not create database through command so go to app/config/database.php and set your database configuration. details here

'mysql' => array(
    'read' => array(
        'host' => '192.168.1.1',
    ),
    'write' => array(
        'host' => '196.168.1.2'
    ),
    'driver'    => 'mysql',
    'database'  => 'database',
    'username'  => 'root',
    'password'  => '',
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
),

after setting you can create table through command

php artisan migrate:make create_user_table --table=users

it will generate a file to app/database/migrations name create_users_table. . . . . then you create your table following this link

and finally run this command php artisan migrate

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!