Symfony2 like database creation command in laravel console?

若如初见. 提交于 2019-12-30 13:40:29

问题


I have used symfony2 console to create database. If I want to create a database named "symfony" I usually mentioned that name in parameters.yml file and run the below command in console

php app/console  doctrine:database:create

But when came to laravel, I don't find similar command to create database in laravel. Can anyone help me to find out those command to create database directly from Laravel Console.


回答1:


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');



回答2:


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.




回答3:


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



来源:https://stackoverflow.com/questions/27813801/symfony2-like-database-creation-command-in-laravel-console

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