-1

我想使用多个数据库,我有1db/user和 1 个主 db,已经在配置文件中设置了主 db,但是如何管理用户数据库(db name = {user_id}_db)。提前致谢

这是我的配置代码

'main' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST', '127.0.0.1'),
    'port' => env('DB_PORT', '3306'),
    'database' => env('DB_DATABASE', 'forge'),
    'username' => env('DB_USERNAME', 'forge'),
    'password' => env('DB_PASSWORD', ''),
    'unix_socket' => env('DB_SOCKET', ''),
    'charset' => 'utf8mb4',
    'collation' => 'utf8mb4_unicode_ci',
    'prefix' => '',
    'strict' => true,
    'engine' => null,
],
4

2 回答 2

0

为每个用户创建数据库是没有用的,即使您是为了安全或任何其他目的而这样做。有用的 SO 链接MySQL 性能:多个表与单个表和分区上的索引

您的问题(连接到 Laravel 中的多个数据库)已在此处得到解答。如何在 Laravel 中使用多个数据库

更新

我想,您想即时创建新数据库并连接到它们(不使用 .env 配置)。尝试连接到新数据库时,创建动态连接而不是指定“连接名称”。然后,使用Config::set您可以创建新的临时连接,然后使用DB::connection您刚刚创建的临时名称。阅读更多https://lukevers.com/2015/03/25/on-the-fly-database-connections-with-laravel-5

于 2019-01-30T05:25:19.687 回答
0

您可以对多个数据库使用以下配置。

<?php
return array(

    'default' => 'mysql',

    'connections' => array(

        # primary 
        'mysql' => array(
            'driver'    => 'mysql',
            'host'      => 'ip1',
            'database'  => 'db1',
            'username'  => 'user',
            'password'  => 'pwd'
            'charset'   => 'utf8',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix'    => '',
        ),

        # secondary db connection
        'mysql2' => array(
            'driver'    => 'mysql',
            'host'      => 'dbip2',
            'database'  => 'db2',
            'username'  => 'user',
            'password'  => 'pwd'
            'charset'   => 'utf8',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix'    => '',
            'strict' => true,
            'engine' => null
        ),
        'sqlite' => array(
            'driver'   => 'sqlite',
            'database' => __DIR__.'/../database/db.sqlite',
            'prefix'   => '',
        ),
    ),
);

然后你可以使用 connection() 方法:

$connection = ‘mysql2’;

Schema::connection($connection)->create(function(Blueprint $table) {

//

});
于 2019-01-30T05:58:33.347 回答