gpt4 book ai didi

php - 每个数据库使用一个 Laravel 迁移表

转载 作者:可可西里 更新时间:2023-10-31 22:40:19 25 4
gpt4 key购买 nike

我在一个使用多个数据库的项目中工作。看起来 Laravel 只使用数据库中设置为默认的迁移表。我希望每个数据库有一个迁移表,用于记录对该特定数据库所做的迁移。这可能吗?

我在配置中定义了这样的数据库:

'connections' => [
'db1' => array(
'driver' => 'mysql',
'host' => 'db1.host',
'database' => 'db1',
'username' => 'username',
'password' => 'password',
),
'db2' => [
'driver' => 'mysql',
'host' => 'db2.host',
'database' => 'db2',
'username' => 'username',
'password' => 'password',
]
],

我还将第一个数据库 (db1) 设置为默认数据库

'default' => 'db1'

我在两个数据库上都安装了迁移表

artisan migrate:install --database=db1
artisan migrate:install --database=db2

之后我继续创建几个特定于数据库的迁移

在 db1 数据库中创建表 test1:

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateTest1Table extends Migration
{
public function up()
{
Schema::connection('db1')->create('test1', function(Blueprint $table)
{
$table->increments('id')->unsigned();
});
}

public function down()
{
Schema::connection('db1')->drop('test1');
}
}

在 db2 数据库中创建表 test2:

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateTest2Table extends Migration
{
public function up()
{
Schema::connection('db2')->create('test2', function(Blueprint $table)
{
$table->increments('id')->unsigned();
});
}

public function down()
{
Schema::connection('db2')->drop('test2');
}
}

我现在运行迁移

artisan migrate

预期结果

db1.迁移

+-----------------------------+-------+
| migration | batch |
+-----------------------------+-------+
| create_test1_table_in_db1 | 1 |
+-----------------------------+-------+

db2.migrations

+-----------------------------+-------+
| migration | batch |
+-----------------------------+-------+
| create_test2_table_in_db2 | 1 |
+-----------------------------+-------+

实际结果

db1.迁移

+-----------------------------+-------+
| migration | batch |
+-----------------------------+-------+
| create_test1_table_in_db1 | 1 |
| create_test2_table_in_db2 | 1 |
+-----------------------------+-------+

db2.migrations

+-----------------------------+-------+
| migration | batch |
+-----------------------------+-------+
Empty set

最佳答案

Article on usage of multiple database usage in Laravel -https://stackcoder.in/posts/laravel-7x-multiple-database-connections-migrations-relationships-querying

--database 参数与 migrate 命令一起使用,并将每个数据库的迁移存储在单独的目录中。

您可以在 app/database/migrations 中为每个数据库(在您的例子中为 db1db2)创建单独的目录并存储每个目录中的适当迁移。然后你可以像这样运行迁移:

artisan migrate --database="db1" --path="app/database/migrations/db1"
artisan migrate --database="db2" --path="app/database/migrations/db2"

这样您的migrations 表将独立于每个数据库。

如果您想更进一步并使流程自动化,您可以创建自定义命令来一次运行所有迁移。您可以像这样创建命令(对 Laravel 5.0 至 5.2 使用 make:console 或对 Laravel 5.2+ 使用 make:command):

artisan command:make MigrateAllCommand --command=migrate:all

这将创建一个新文件 app/commands/MigrateAllCommand.php。您命令的 fire 方法看起来像这样:

public function fire()
{
foreach (Config::get('database.connections') as $name => $details)
{
$this->info('Running migration for "' . $name . '"');
$this->call('migrate', array('--database' => $name, '--path' => 'app/database/migrations/' . $name));
}
}

如果数据库配置键的名称与迁移目录名称相同,这将起作用。然后你可以这样调用它:

artisan migrate:all

您可以查看 Laravel Command Docs了解更多信息。

关于php - 每个数据库使用一个 Laravel 迁移表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26654846/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com