Laravel如何同时连接多个数据库详解
程序员文章站
2022-05-25 23:08:26
前言
上文说到的文章,然后在总结下laravel同时连接
多个数据库的实例,方便新手学习,db连接以及model连接。
配置.env 文件
db_c...
前言
上文说到的文章,然后在总结下laravel同时连接
多个数据库的实例,方便新手学习,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 { // 数据库'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();
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
上一篇: PHP基于swoole多进程操作示例
下一篇: AngularJS学习笔记之依赖注入详解