前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel如何同时连接多个数据库详解

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

作者头像
砸漏
发布2020-10-20 10:33:08
1.6K0
发布2020-10-20 10:33:08
举报
文章被收录于专栏:恩蓝脚本

前言

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

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

配置.env 文件

代码语言:javascript
复制
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

代码语言:javascript
复制
// 默认连接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连接)

代码语言:javascript
复制
<?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’连接)

代码语言:javascript
复制
<?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实例

代码语言:javascript
复制
// 以下是调用方法
Test::get();
Test::where('id',1)- first();

DB直接连接数据库

代码语言:javascript
复制
// 连接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();

总结

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档