Laravel如何同時連接多個數(shù)據(jù)庫詳解
前言
上文說到thinkphp3.2同時連接兩個數(shù)據(jù)庫的文章,然后在總結(jié)下laravel同時連接
多個數(shù)據(jù)庫的實例,方便新手學習,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
// 默認連接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
{
// 數(shù)據(jù)庫'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
{
// 數(shù)據(jù)庫'database'中的test表
public $table = 'test';
public $timestamps = false;
// 以下代碼可有可不、默認連接mysql
protected $connection = 'mysql';
}
a、這個model將采用默認的'mysql'連接
class UserModel extends Model
{
// 數(shù)據(jù)庫'database'中的users表
protected $table = "users";
}
b、
調(diào)用model實例
// 以下是調(diào)用方法
Test::get();
Test::where('id',1)->first();
DB直接連接數(shù)據(jù)庫
// 連接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();
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。
- Laravel5.1數(shù)據(jù)庫連接、創(chuàng)建數(shù)據(jù)庫、創(chuàng)建model及創(chuàng)建控制器的方法
- Laravel5.5 數(shù)據(jù)庫遷移:創(chuàng)建表與修改表示例
- Laravel5.7 數(shù)據(jù)庫操作遷移的實現(xiàn)方法
- 在Laravel5.6中使用Swoole的協(xié)程數(shù)據(jù)庫查詢
- Laravel框架DB facade數(shù)據(jù)庫操作詳解
- Laravel監(jiān)聽數(shù)據(jù)庫訪問,打印SQL的例子
- Laravel框架使用monolog_mysql實現(xiàn)將系統(tǒng)日志信息保存到mysql數(shù)據(jù)庫的方法
- PHP的Laravel框架結(jié)合MySQL與Redis數(shù)據(jù)庫的使用部署
- Laravel框架數(shù)據(jù)庫CURD操作、連貫操作總結(jié)
- PHP開發(fā)框架Laravel數(shù)據(jù)庫操作方法總結(jié)
- Laravel5.1 框架數(shù)據(jù)庫操作DB運行原生SQL的方法分析
相關(guān)文章
Zend Framework實現(xiàn)留言本分頁功能(附demo源碼下載)
這篇文章主要介紹了Zend Framework實現(xiàn)留言本分頁功能,詳細分析了Zend Framework實現(xiàn)留言本所涉及的控制器動作,分頁樣式及模板調(diào)用技巧,并附代碼demo源碼供讀者下載參考,需要的朋友可以參考下2016-03-03
利用phpexcel把excel導入數(shù)據(jù)庫和數(shù)據(jù)庫導出excel實現(xiàn)
本文介紹利用phpexcel對數(shù)據(jù)庫數(shù)據(jù)導入excel(excel篩選)、導出excel,大家參考使用吧2014-01-01
PHP+Ajax實現(xiàn)上傳文件進度條動態(tài)顯示進度功能
這篇文章主要介紹了PHP+Ajax實現(xiàn)上傳文件進度條動態(tài)顯示進度功能,通過ajax實現(xiàn)主界面,php處理上傳文件,具體實例代碼大家跟隨腳本之家小編一起看看吧2018-06-06
PHP獲取不了React Native Fecth參數(shù)的解決辦法
這篇文章的主要內(nèi)容是解決PHP獲取不了React Native Fecth參數(shù)的問題,本文通過示例詳細解釋如何解決這個問題,相信對大家的理解更有幫助,如果有這個問題的可以參考下本文,下面跟著小編一起來看看。2016-08-08

