在 Laravel 中将数据库克隆为不同的名称

Mah*_*n S 7 php mysql phpmyadmin laravel laravel-5

嗨,我是 Laravel 的新手。

在我们的项目中,我们必须将当前数据库克隆到具有不同名称的同一服务器中。例如,如果我们当前的数据库名称是“test”意味着,我必须将数据库(test)克隆到具有不同名称的同一服务器中,例如“test_2018”我需要数据库(test)中的所有表到我们的克隆数据库(test_2018)。

我如何以编程方式在 Laravel 中实现这一点,并且我使用了 Laravel 5.0 版。

Ali*_*Ali 2

我假设您使用的是 MySql 数据库。

您可以创建一个批处理文件,然后使用 Laravel 中的任务计划程序调用该文件。在文件中的 Laravel 项目中App\Console\Kernel.php,将此行添加到计划函数中以每年运行该命令。

protected function schedule(Schedule $schedule)
    {
         $schedule->exec('/batch.bat')->yearly();
    }
Run Code Online (Sandbox Code Playgroud)

如果您有 Windows,则需要使用任务计划程序创建计划任务,如果您有 Linux(90% 您有 Linux,特别是如果您的项目在托管服务器上运行),那么您应该创建一个 CRON 作业并放置此脚本在你的脚本中(根据 Laravel文档):

* * * * * cd /path-to-your-project && php artisan schedule:run >> /dev/null 2>&1
Run Code Online (Sandbox Code Playgroud)

然后在项目文件夹中创建一个batch.bat(Windows) 或batch.sh(Linux) 文件,并将以下内容放入其中:

mysql -u [USER-NAME] -p[PASSWORD] [YOUR-CURRENT-DATABASE-NAME] > /dumpfile.sql
CREATE DATABASE [NEW-DATABASE-NAME];
[NEW-DATABASE-NAME] < /dumpfile.sql
Run Code Online (Sandbox Code Playgroud)

不要等待,立即使用以下命令手动测试它:

php artisan schedule:run
Run Code Online (Sandbox Code Playgroud)