1. 程式人生 > >簡單幾部搞定laravel/lumen跨庫操作

簡單幾部搞定laravel/lumen跨庫操作

mil tom fig文件 brush localhost utf except conn strong

1.跨庫數據庫配置

在網站跟目錄下的config文件中增加database.php作為數據庫配置文件。配置如下:

//當前默認數據庫

'mysql' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST', 'localhost'),
    'port' => env('DB_PORT', 3306),
    'database' => env('DB_DATABASE', 'forge'),
    'username' => env('DB_USERNAME', 'forge'),
    'password' => env('DB_PASSWORD', ''),
    'charset' => env('DB_CHARSET', 'utf8'),
    'collation' => env('DB_COLLATION', 'utf8_unicode_ci'),
    'prefix' => env('DB_PREFIX', ''),
    'timezone' => env('DB_TIMEZONE', '+00:00'),
    'strict' => env('DB_STRICT_MODE', false),
],
----------------------------------重磅內容來襲----------------------------------------------------

//增加其他庫

'xd_db' => [
    'driver' => 'mysql',
    'host' => env('XD_DB_HOST', 'localhost'),
    'port' => env('XD_DB_PORT', 3306),
    'database' => env('XD_DB_DATABASE', 'forge'),
    'username' => env('XD_DB_USERNAME', 'forge'),
    'password' => env('XD_DB_PASSWORD', ''),
    'charset' => env('XD_DB_CHARSET', 'utf8'),
    'collation' => env('XD_DB_COLLATION', 'utf8_unicode_ci'),
    'prefix' => env('XD_DB_PREFIX', ''),
    'timezone' => env('XD_DB_TIMEZONE', '+00:00'),
    'strict' => env('XD_DB_STRICT_MODE', false),
],


2.跨庫Model操作

只需要在model中增加下面語句即可,使用Model方式照舊:
protected $connection='xd_db';//指定數據庫

代碼演示

class Customer extends Model
{
    protected $connection="xd_db";//指定數據庫
    protected $table = "customer";
    public $timestamps = false;
    
    ....
}


使用Model方式不發生任何變化。
Customer::where(...);



3.跨庫DB原生操作

DB後面通過增加connection()方法指定要連接的數據庫。

註意:常見的DB操作的默認指定的數據庫配置標示名為database.php中的‘mysql’。

DB::where('...')
等同於
DB::connection('mysql')->where();


同理,只需要指定需要連接的數據庫的配置標示名即可實現跨庫操作。

DB::connection('xd_db')->where();



4.跨庫事務

默認事務操作範例:

try {
    DB::beginTransaction();
    
    ....業務操作....
    
    
    DB::commit();
}catch(\Exception $e){
    DB::rollback();
    throw $e;
}


跨庫事務

try {
    DB::connection('xd_db')->beginTransaction();
    
    ....業務操作....
    
    
    DB::::connection('xd_db')->commit();
}catch(\Exception $e){
    DB::::connection('xd_db')->rollback();
    throw $e;
}


至此,關於laravel/lulem的所有有關跨庫的操作均給出了具體操作方案。歡迎提出意見!

簡單幾部搞定laravel/lumen跨庫操作