簡體   English   中英

如何在Laravel中將另一個數據庫與模型連接

[英]How to connect another database with model in laravel

我可以像這樣連接另一個數據庫

DB::connection('connection_2')->table("users")->get();

但是這段代碼不起作用

User::connection('connection_2')->get();

您需要像這樣設置模型的$connection屬性:

class MyModel extends Eloquent {
    protected $connection = 'connection_2';
}

在database.php中添加:

'main' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST', 'localhost'),
    'database' => env('DB_MAIN', 'forge'),
    'username' => env('DB_USERNAME', 'forge'),
    'password' => env('DB_PASSWORD', ''),
    'charset' => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix' => '',
    'strict' => false
],
'admin' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST', 'localhost'),
    'database' => env('DB_ADMIN', 'forge'),
    'username' => env('DB_USERNAME', 'forge'),
    'password' => env('DB_PASSWORD', ''),
    'charset' => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix' => '',
    'strict' => false
]

然后使用:

DB::connection('main')->table("users")->get();
DB::connection('admin')->table("users")->get();

在您的User.php模型中:

class User extends Model
{
    protected $connection = 'main';
    protected $table = 'users';
    protected $fillable = [
       'id','name'
    ];
}

然后使用:

User::get();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM