侧边栏壁纸
博主头像
落叶人生博主等级

走进秋风,寻找秋天的落叶

  • 累计撰写 130562 篇文章
  • 累计创建 28 个标签
  • 累计收到 9 条评论
标签搜索

目 录CONTENT

文章目录

Laravel如何同时连接多个数据库详解

2022-07-04 星期一 / 0 评论 / 0 点赞 / 99 阅读 / 3134 字

前言上文说到thinkphp3.2同时连接两个数据库的文章,然后在总结下laravel同时连接多个数据库的实例,方便新手学习,db连接以及model连接。配置.env 文件DB_CONNECTION=mysqlDB_HO

前言

上文说到thinkphp3.2同时连接两个数据库的文章,然后在总结下laravel同时连接

多个数据库的实例,方便新手学习,db连接以及model连接。

配置.env 文件

.
DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_PORT=3306DB_DATABASE=database_nameDB_USERNAME=rootDB_PASSWORD=rootDB_HOST_TEST=127.0.0.1DB_PORT_TEST=3306DB_DATABASE_TEST=database_testDB_USERNAME_TEST=rootDB_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连接)

.
<?phpnamespace 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'连接)

.
<?phpnamespace 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();
.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对..的支持。

广告 广告

评论区