您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關利用Laravel怎么同時連接多個數據庫,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
配置.env 文件
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=database_name DB_USERNAME=root DB_PASSWORD=root DB_HOST_TEST=127.0.0.1 DB_PORT_TEST=3306 DB_DATABASE_TEST=database_test DB_USERNAME_TEST=root DB_PASSWORD_TEST=root
配置 config/database.php
// 默認連接mysql 'default' => env('DB_CONNECTION', 'mysql'), 'connections' => [ 'sqlite' => [ 'driver' => 'sqlite', 'database' => database_path('database.sqlite'), 'prefix' => '', ], 'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'database_name'), 'username' => env('DB_USERNAME', 'root'), 'password' => env('DB_PASSWORD', 'root'), 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ], 'mysql_test' => [ 'driver' => 'mysql', 'host' => env('DB_HOST_TEST', '127.0.0.1'), 'port' => env('DB_PORT_TEST', '3306'), 'database' => env('DB_DATABASE_TEST', 'database_test'), 'username' => env('DB_USERNAME_TEST', 'root'), 'password' => env('DB_PASSWORD_TEST', 'root'), 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ], ],
model實例(這個model將使用mysql_test連接)
<?php namespace App\Model; use Illuminate\Database\Eloquent\Model; class Test extends Model { // 數據庫'database_test'中的test表 public $table = 'test'; public $timestamps = false; protected $connection = 'mysql_test'; }
model實例(這個model將采用默認的'mysql'連接)
<?php namespace App\Model; use Illuminate\Database\Eloquent\Model; class Test extends Model { // 數據庫'database'中的test表 public $table = 'test'; public $timestamps = false; // 以下代碼可有可不、默認連接mysql protected $connection = 'mysql'; } a、這個model將采用默認的'mysql'連接 class UserModel extends Model { // 數據庫'database'中的users表 protected $table = "users"; } b、
調用model實例
// 以下是調用方法 Test::get(); Test::where('id',1)->first();
DB直接連接數據庫
// 連接mysql_test庫 DB::connection('mysql_test')->table('test')->where('id',1)->first(); // 連接mysql庫 DB::connection('mysq')->table('test')->where('id',1)->first(); // 連接mysql庫 DB::table('test')->where('id',1)->first();
看完上述內容,你們對利用Laravel怎么同時連接多個數據庫有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。