使用 Laravel 應用程式時,經常會遇到需要多個資料庫的情況。在這種情況下,了解如何在 Laravel 應用程式中有效管理這些資料庫並與之互動至關重要。
Laravel 提供了資料庫外觀,它作為存取不同的資料庫連接。透過利用資料庫門面提供的連接方法,開發人員可以建立和檢索與多個資料庫的連接。連線方法需要一個與 config/database.php 設定檔中定義的連線名稱對應的參數。
$users = DB::connection('foo')->select(...);
使用.env:
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=mysql_database DB_USERNAME=root DB_PASSWORD=secret DB_CONNECTION_PGSQL=pgsql DB_HOST_PGSQL=127.0.0.1 DB_PORT_PGSQL=5432 DB_DATABASE_PGSQL=pgsql_database DB_USERNAME_PGSQL=root DB_PASSWORD_PGSQL=secret
使用config/database.php:
'mysql' => [ 'driver' => env('DB_CONNECTION'), 'host' => env('DB_HOST'), 'port' => env('DB_PORT'), 'database' => env('DB_DATABASE'), 'username' => env('DB_USERNAME'), 'password' => env('DB_PASSWORD'), ], 'pgsql' => [ 'driver' => env('DB_CONNECTION_PGSQL'), 'host' => env('DB_HOST_PGSQL'), 'port' => env('DB_PORT_PGSQL'), 'database' => env('DB_DATABASE_PGSQL'), 'username' => env('DB_USERNAME_PGSQL'), 'password' => env('DB_PASSWORD_PGSQL'), ],
沒有.env (Laravel :
return array( 'default' => 'mysql', 'connections' => array( 'mysql' => array( 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'mysql_database', 'username' => 'root', 'password' => 'secret', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ), 'pgsql' => [ 'driver' => 'pgsql', 'host' => 'localhost', 'port' => '5432', 'database' => 'pgsql_database', 'username' => 'root', 'password' => 'secret', 'charset' => 'utf8', 'prefix' => '', 'schema' => 'public', ] ), );
Schema:
連接方法可以用來指定資料庫進行schema操作:
Schema::connection('pgsql')->create('some_table', function($table){ ... });
查詢Builder:
$users = DB::connection('pgsql')->select(...);
Models:
可以在模型中明確定義連接class:
class ModelName extends Model { protected $connection = 'pgsql'; }
Eloquent:
class SomeModel extends Eloquent { protected $connection = 'pgsql'; }
交易也可以跨多個資料庫管理:
DB::transaction(function () { DB::connection('mysql')->table('users')->update(...); DB::connection('pgsql')->table('orders')->update(...); });
連線可以動態設定:
$someModel = new SomeModel; $someModel->setConnection('pgsql'); // non-static $something = $someModel->find(1); $something = SomeModel::on('pgsql')->find(1); // static
處理不同資料庫之間的關係時,請務必小心。這是可能的,但可能需要仔細考慮資料庫設定。
以上是如何在 Laravel 管理多個資料庫連線?的詳細內容。更多資訊請關注PHP中文網其他相關文章!