Laravel如何同时连接多个数据库详解
发布:smiling 来源: PHP粉丝网 添加日期:2021-12-10 17:03:58 浏览: 评论:0
这篇文章主要给大家介绍了关于Laravel如何同时连接多个数据库的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Laravel具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
前言
上文说到thinkphp3.2同时连接两个数据库的文章,然后在总结下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();
Tags: Laravel连接数据库
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)