Laravel框架实现多数据库连接操作详解
本文实例讲述了Laravel框架实现多数据库连接操作。分享给大家供大家参考,具体如下:
这篇文章介绍了在laravel中连接2个数据库的方法
一、定义连接
进入到数据库配置文件app/config/database.php中,你可以定义多个形式相同或不同的数据库连接。例如,你想从2个MYSQL数据中抓取资料到你的程式中,你可以这样定义:
'mysql', 'connections'=>array( #Ourprimarydatabaseconnection 'mysql'=>array( 'driver'=>'mysql', 'host'=>'host1', 'database'=>'database1', 'username'=>'user1', 'password'=>'pass1' 'charset'=>'utf8', 'collation'=>'utf8_unicode_ci', 'prefix'=>'', ), #Oursecondarydatabaseconnection 'mysql2'=>array( 'driver'=>'mysql', 'host'=>'host2', 'database'=>'database2', 'username'=>'user2', 'password'=>'pass2' 'charset'=>'utf8', 'collation'=>'utf8_unicode_ci', 'prefix'=>'', ), ), );
默认连接任然是mysql,除非指定其他连接,如mysql2,我们的连接都是mysql连接。
2、指定连接
现在我们来指定mysql2连接,怎么做呢:
Schema数据库迁移
用Schemafacade可以创建任意连接。现在只需要用connection()方法就可以在指定的数据库中创建table
Schema::connection('mysql2')->create('some_table',function($table) { $table->increments('id'): });
如果不加connection()方法,就是在默认的数据库中创建table
查询
和上面一样,用connection()方法
$users=DB::connection('mysql2')->select(...);
Eloquent
在模型中指定连接数据库方法,在模型中设置$connection变量
在控制器中用setConnection方法也可连接指定数据库
setConnection('mysql2'); $something=$someModel->find(1); return$something; } }跨数据库连接是可以的,但是也可能带来一些问题,这取决于你的数据库或者数据库配置,所以要谨慎使用。
原文地址:http://fideloper.com/laravel-multiple-database-connections
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。