Mah*_*n S 7 php mysql phpmyadmin laravel laravel-5
嗨,我是 Laravel 的新手。
在我们的项目中,我们必须将当前数据库克隆到具有不同名称的同一服务器中。例如,如果我们当前的数据库名称是“test”意味着,我必须将数据库(test)克隆到具有不同名称的同一服务器中,例如“test_2018”我需要数据库(test)中的所有表到我们的克隆数据库(test_2018)。
我如何以编程方式在 Laravel 中实现这一点,并且我使用了 Laravel 5.0 版。
我假设您使用的是 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)
归档时间: |
|
查看次数: |
1446 次 |
最近记录: |