详解Laravel使用多数据库的方法(附代码示例)

下面带大家了解关于Laravel使用多个数据库的方法,希望对大家有所帮助! 使用.env>= 5.0(测试基于 5.5 Laravel 8 也可用) 在.env文件 DB_C...

下面带大家了解关于Laravel使用多个数据库的方法,希望对大家有所帮助!

使用.env>= 5.0(测试基于 5.5 Laravel 8 也可用)

在.env文件

DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_PORT=3306DB_DATABASE=database1DB_USERNAME=rootDB_PASSWORD=secretDB_CONNECTION_SECOND=mysqlDB_HOST_SECOND=127.0.0.1DB_PORT_SECOND=3306DB_DATABASE_SECOND=database2DB_USERNAME_SECOND=rootDB_PASSWORD_SECOND=secret

在config/database.php文件

'mysql'=>['driver'=>env('DB_CONNECTION'),'host'=>env('DB_HOST'),'port'=>env('DB_PORT'),'database'=>env('DB_DATABASE'),'username'=>env('DB_USERNAME'),'password'=>env('DB_PASSWORD'),],'mysql2'=>['driver'=>env('DB_CONNECTION_SECOND'),'host'=>env('DB_HOST_SECOND'),'port'=>env('DB_PORT_SECOND'),'database'=>env('DB_DATABASE_SECOND'),'username'=>env('DB_USERNAME_SECOND'),'password'=>env('DB_PASSWORD_SECOND'),],]

注意:在mysql2中,如果db_username和db_password相同, 那么你可以使用env('DB_USERNAME')。

模式

要指定使用哪个连接,只需使用connection()方法

Schema::connection('mysql2')->create('some_table',function($table){$table->increments('id');});

查询生产器

$users=DB::connection('mysql2')->select(...);

模型

在模型中设置$connection变量。

classSomeModelextendsEloquent{protected$connection='mysql2';}

你也可以在运行时通过setConnection方法或on静态方法定义连接:

classSomeControllerextendsBaseController{publicfunctionsomeMethod(){$someModel=newSomeModel;$someModel->setConnection('mysql2');//non-staticmethod$something=$someModel->find(1);$something=SomeModel::on('mysql2')->find(1);//staticmethodreturn$something;}}

注意在尝试与跨数据库的表建立关系时要小心! 可以这样使用,但是它可能带有一些注意事项,并且取决于您拥有的数据库与数据库设置。

来自 Laravel Docs

使用多个数据库连接

当使用多个连接时,您可以通过DB门面类上的连接方法访问每个连接。传递给connection方法的名称应该对应于config/database.php配置文件中列出的一个连接:

$users=DB::connection('foo')->select(...);

您还可以使用连接实例上的getPdo方法访问原始的底层 PDO 实例:

$pdo=DB::connection()->getPdo();

原文地址:https://stackoverflow.com/questions/31847054/how-to-use-multiple-databases-in-laravel

译文地址:https://learnku.com/laravel/t/62110

产品猿社区致力收录更多优质的商业产品,给服务商以及软件采购客户提供更多优质的软件产品,帮助开发者变现来实现多方共赢;

日常运营的过程中我们难免会遇到各种版权纠纷等问题,如果您在社区内发现有您的产品未经您授权而被用户提供下载或使用,您可按照我们投诉流程处理,点我投诉

本文来自用户发布投稿,不代表产品猿立场 ;若对此文有疑问或内容有严重错误,可联系平台客服反馈;

部分产品是用户投稿,可能本文没有提供官方下下载地址或教程,若您看到的内容没有下载入口,您可以在我们产品园商城搜索看开发者是否有发布商品;若您是开发者,也诚邀您入驻商城平台发布的产品,地址:点我进入

如若转载,请注明出处:http://www.chanpinyuan.cn/42975.html;
(0)
上一篇 2023年5月17日 下午4:16
下一篇 2023年5月17日 下午4:16

相关推荐

发表回复

登录后才能评论
分享本页
返回顶部