分布式数据库的配置信息是定义在配置文件里面的,所以一般情况下是无法更改的。另外使用分布式数据库有个不足,就是无法同时连接多个不同类型的数据库。
多数据库支持
如果你的应用需要在特殊的时候连接多个数据库,那么可以尝试使用ThinkPHP的多数据库连接特性:包括相同类型的数据库和不同类型的数据库。
我们首先需要在模型类里面增加需要的数据库连接,例如:
我们在UserModel类增加多个数据库连接
首先定义额外的数据库连接信息
$myConnect1 = array( ‘dbms’ => ’mysql’, ‘username’ => ’username’, ‘password’ => ’password’, ‘hostname’ => ’localhost’, ‘hostport’ => ’3306′, ‘database’ => ’dbname’ );
或者使用下面的定义
$myConnect1 = ’mysql://username:passwd@localhost:3306/DbName’;
定义之后就可以进行动态的增加和切换数据库了。
$User = D(”User”); // 增加数据库连接 第二个参数表示连接的序号 // 注意内置的数据库连接序号是0,所以额外的数据库连接序号应该从1开始 $User->addConnect($myConnect1,1); // 可以同时增加多个数据库连接 myConnect2和myConnect3的定义方式同myConnect1 $User->addConnect($myConnect1,1); $User->addConnect($myConnect2,2); $User->addConnect($myConnect3,3);
这样在UserModel里面就同时存在了4个数据库(加上项目配置里面定义的)连接。那么我们如何使用这些不同的数据库连接呢?ThinkPHP采用了灵活的切换机制,由应用来控制不同的数据库连接。例如,我们需要在其中一个应用里面用到$myConnect2 这个数据库连接,那么用下面的方法切换即可:
$User->switchConnect(2);
switchConnect方法会智能识别该连接是否是相同类型的连接。
我们还可以使用addConnect方法添加多个动态数据库连接,只要传入数组参数就可以了,例如:
$myConnect[1] = ’mysql://username:passwd@192.168.1.1:3306/DbName1′; $myConnect[2] = ’mysqli://username:passwd@192.168.1.2:3306/DbName2′; $myConnect[3] = ’mysql://username:passwd@192.168.1.3:3306/DbName3′; $User->addConnect($myConnect);
如果需要删除之前动态添加的连接,可以使用delConnect方法,例如:
// 删除连接序号为2的数据库连接 $User->delConnect(2);
可以在使用之后关闭添加的连接,可以使用closeConnect方法,例如:
// 关闭连接序号为3的数据库连接 $User->closeConnect(3);