需求:
有时间需要在php中连接多个数据库,但是在config中只能配置一个默认数据库,那我们怎么实现连接多个数据库呢?
实现:
我的实现方法是这样子的:
研究下ThinkPHP中的M()方法,发现其有三个传参,第一个参数是模型名称(可以包括基础模型类和数据库),第二个参数用于设置数据表的前缀(留空则取当前项目配置的表前缀),第三个参数用于设置当前使用的数据库连接信息(留空则取当前项目配置的数据库连接信息)
用代码实现也就是:M('这个是需要连接的表','这个是表的前缀','连接的参数信息');
。进一步了解。数据库的连接信息可以配置在config中
我们往config中写如下参数'DB_CONFIG1' => array(
'db_type' => 'mysql',
'db_user' => 'root',
'db_pwd' => '',
'db_host' => 'localhost',
'db_name' => 'user',
),
然后使用M()方法。dump出其值$data = M('user','us_','DB_CONFIG1')->select();
dump($data);
打开网页,发现已经显示了user数据库中的us_user表中的所有数据