Laravel如何同時(shí)連接多個(gè)數(shù)據(jù)庫(kù)詳解
前言
上文說到thinkphp3.2同時(shí)連接兩個(gè)數(shù)據(jù)庫(kù)的文章,然后在總結(jié)下laravel同時(shí)連接
多個(gè)數(shù)據(jù)庫(kù)的實(shí)例,方便新手學(xué)習(xí),db連接以及model連接。
配置.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
// 默認(rèn)連接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實(shí)例(這個(gè)model將使用mysql_test連接)
<?php namespace App\Model; use Illuminate\Database\Eloquent\Model; class Test extends Model { // 數(shù)據(jù)庫(kù)'database_test'中的test表 public $table = 'test'; public $timestamps = false; protected $connection = 'mysql_test'; }
model實(shí)例(這個(gè)model將采用默認(rèn)的'mysql'連接)
<?php namespace App\Model; use Illuminate\Database\Eloquent\Model; class Test extends Model { // 數(shù)據(jù)庫(kù)'database'中的test表 public $table = 'test'; public $timestamps = false; // 以下代碼可有可不、默認(rèn)連接mysql protected $connection = 'mysql'; } a、這個(gè)model將采用默認(rèn)的'mysql'連接 class UserModel extends Model { // 數(shù)據(jù)庫(kù)'database'中的users表 protected $table = "users"; } b、
調(diào)用model實(shí)例
// 以下是調(diào)用方法 Test::get(); Test::where('id',1)->first();
DB直接連接數(shù)據(jù)庫(kù)
// 連接mysql_test庫(kù) DB::connection('mysql_test')->table('test')->where('id',1)->first(); // 連接mysql庫(kù) DB::connection('mysq')->table('test')->where('id',1)->first(); // 連接mysql庫(kù) DB::table('test')->where('id',1)->first();
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
- Laravel5.1數(shù)據(jù)庫(kù)連接、創(chuàng)建數(shù)據(jù)庫(kù)、創(chuàng)建model及創(chuàng)建控制器的方法
- Laravel5.5 數(shù)據(jù)庫(kù)遷移:創(chuàng)建表與修改表示例
- Laravel5.7 數(shù)據(jù)庫(kù)操作遷移的實(shí)現(xiàn)方法
- 在Laravel5.6中使用Swoole的協(xié)程數(shù)據(jù)庫(kù)查詢
- Laravel框架DB facade數(shù)據(jù)庫(kù)操作詳解
- Laravel監(jiān)聽數(shù)據(jù)庫(kù)訪問,打印SQL的例子
- Laravel框架使用monolog_mysql實(shí)現(xiàn)將系統(tǒng)日志信息保存到mysql數(shù)據(jù)庫(kù)的方法
- PHP的Laravel框架結(jié)合MySQL與Redis數(shù)據(jù)庫(kù)的使用部署
- Laravel框架數(shù)據(jù)庫(kù)CURD操作、連貫操作總結(jié)
- PHP開發(fā)框架Laravel數(shù)據(jù)庫(kù)操作方法總結(jié)
- Laravel5.1 框架數(shù)據(jù)庫(kù)操作DB運(yùn)行原生SQL的方法分析
相關(guān)文章
php實(shí)現(xiàn)文章評(píng)論系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了php實(shí)現(xiàn)文章評(píng)論系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02thinkPHP3.0框架實(shí)現(xiàn)模板保存到數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了thinkPHP3.0框架實(shí)現(xiàn)模板保存到數(shù)據(jù)庫(kù)的方法,結(jié)合實(shí)例形式分析了使用thinkPHP3.0框架開發(fā)CMS系統(tǒng)過程中將模板保存到數(shù)據(jù)庫(kù)的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-08-08Thinkphp框架 表單自動(dòng)驗(yàn)證登錄注冊(cè) ajax自動(dòng)驗(yàn)證登錄注冊(cè)
這篇文章主要介紹了Thinkphp框架 表單自動(dòng)驗(yàn)證登錄注冊(cè) ajax自動(dòng)驗(yàn)證登錄注冊(cè)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12ThinkPHP做文字水印時(shí)提示call an undefined function exif_imagetype()解
這篇文章主要介紹了ThinkPHP做文字水印時(shí)提示call an undefined function exif_imagetype()解決方法,是項(xiàng)目開發(fā)中非常實(shí)用的技巧,需要的朋友可以參考下2014-10-10