Laravel如何实现多数据库连接及详细配置技巧?
- 内容介绍
- 文章标签
- 相关推荐
本文共计733个文字,预计阅读时间需要3分钟。
前言:本文将介绍如何在ThinkPHP3.2中同时连接两个数据库的文档,并随后在Laravel中实现同时连接多个数据库的实例,方便新手学习。以下是详细的步骤和配置。
上文说到的ThinkPHP3.2配置:
配置文件:application/database.php
'databases'=> [ // 默认数据库配置 'default'=> [ 'type'=> 'mysql', 'hostname'=> '127.0.0.1', 'database'=> 'default_db', 'username'=> 'root', 'password'=> '', 'hostport'=> '3306', 'params'=> [], 'charset'=> 'utf8', 'prefix'=> 'tp_', ], // 第二个数据库配置 'second_db'=> [ 'type'=> 'mysql', 'hostname'=> '127.0.0.1', 'database'=> 'second_db', 'username'=> 'root', 'password'=> '', 'hostport'=> '3306', 'params'=> [], 'charset'=> 'utf8', 'prefix'=> 'sd_', ],],
Laravel配置:
配置文件:config/database.php
'driver'=> 'mysql','connections'=> [ 'default'=> [ 'driver'=> 'mysql', 'host'=> env('DB_HOST', '127.0.0.1'), 'port'=> env('DB_PORT', '3306'), 'database'=> env('DB_DATABASE', 'forge'), 'username'=> env('DB_USERNAME', 'forge'), 'password'=> env('DB_PASSWORD', ''), 'charset'=> 'utf8', 'collation'=> 'utf8_unicode_ci', 'prefix'=> '', ], // 第二个数据库连接配置 'second_db'=> [ 'driver'=> 'mysql', 'host'=> env('SECOND_DB_HOST', '127.0.0.1'), 'port'=> env('SECOND_DB_PORT', '3306'), 'database'=> env('SECOND_DB_DATABASE', 'second_db'), 'username'=> env('SECOND_DB_USERNAME', 'root'), 'password'=> env('SECOND_DB_PASSWORD', ''), 'charset'=> 'utf8', 'collation'=> 'utf8_unicode_ci', 'prefix'=> '', ], // 更多数据库连接配置...],
`.env` 文件配置:
DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_DATABASE=default_dbDB_USERNAME=rootDB_PASSWORD=
SECOND_DB_HOST=127.0.0.1SECOND_DB_DATABASE=second_dbSECOND_DB_USERNAME=rootSECOND_DB_PASSWORD=
通过以上配置,你可以在ThinkPHP3.2和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();
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对易盾网络的支持。
本文共计733个文字,预计阅读时间需要3分钟。
前言:本文将介绍如何在ThinkPHP3.2中同时连接两个数据库的文档,并随后在Laravel中实现同时连接多个数据库的实例,方便新手学习。以下是详细的步骤和配置。
上文说到的ThinkPHP3.2配置:
配置文件:application/database.php
'databases'=> [ // 默认数据库配置 'default'=> [ 'type'=> 'mysql', 'hostname'=> '127.0.0.1', 'database'=> 'default_db', 'username'=> 'root', 'password'=> '', 'hostport'=> '3306', 'params'=> [], 'charset'=> 'utf8', 'prefix'=> 'tp_', ], // 第二个数据库配置 'second_db'=> [ 'type'=> 'mysql', 'hostname'=> '127.0.0.1', 'database'=> 'second_db', 'username'=> 'root', 'password'=> '', 'hostport'=> '3306', 'params'=> [], 'charset'=> 'utf8', 'prefix'=> 'sd_', ],],
Laravel配置:
配置文件:config/database.php
'driver'=> 'mysql','connections'=> [ 'default'=> [ 'driver'=> 'mysql', 'host'=> env('DB_HOST', '127.0.0.1'), 'port'=> env('DB_PORT', '3306'), 'database'=> env('DB_DATABASE', 'forge'), 'username'=> env('DB_USERNAME', 'forge'), 'password'=> env('DB_PASSWORD', ''), 'charset'=> 'utf8', 'collation'=> 'utf8_unicode_ci', 'prefix'=> '', ], // 第二个数据库连接配置 'second_db'=> [ 'driver'=> 'mysql', 'host'=> env('SECOND_DB_HOST', '127.0.0.1'), 'port'=> env('SECOND_DB_PORT', '3306'), 'database'=> env('SECOND_DB_DATABASE', 'second_db'), 'username'=> env('SECOND_DB_USERNAME', 'root'), 'password'=> env('SECOND_DB_PASSWORD', ''), 'charset'=> 'utf8', 'collation'=> 'utf8_unicode_ci', 'prefix'=> '', ], // 更多数据库连接配置...],
`.env` 文件配置:
DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_DATABASE=default_dbDB_USERNAME=rootDB_PASSWORD=
SECOND_DB_HOST=127.0.0.1SECOND_DB_DATABASE=second_dbSECOND_DB_USERNAME=rootSECOND_DB_PASSWORD=
通过以上配置,你可以在ThinkPHP3.2和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();
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对易盾网络的支持。

