当前位置: 移动技术网 > IT编程>开发语言>PHP > Yii框架实现多数据库配置和操作的方法

Yii框架实现多数据库配置和操作的方法

2017年12月12日  | 移动技术网IT编程  | 我要评论

互联星空软件下载,丝路飘香,抚顺吧

本文实例讲述了yii框架实现多数据库配置和操作的方法。分享给大家供大家参考,具体如下:

yii的默认配置为一个数据库,不过可以很容易的支持多个数据库的操作,

这为按业务分割数据库提供了基础设施。如下所示:

//cms db connection
'db' => (defined('db_connection') ? array(
  'connectionstring' => db_connection,
  'username' => db_user,
  'password' => db_pwd,
  'charset' => 'utf8',
  'emulateprepare' => true,
  'enableparamlogging' => true,
  'schemacachingduration' => 3600, //cache table schema
    ) : array()),
//member db connection
'db_member' => (defined('db_connection_member') ? array(
  'class'=> 'cdbconnection' ,
  'connectionstring' => db_connection_member,
  'username' => db_user_member,
  'password' => db_pwd_member,
  'charset' => 'utf8',
  'emulateprepare' => true,
  'enableparamlogging' => true,
  'schemacachingduration' => 3600, //cache table schema
    ) : array()),

然后在模型中重载getdbconnection函数,比如:

class point extends cactiverecord {
  public function getdbconnection() {
     return yii::app()->db_member;
  }
  ...
}

如果有很多模型会使用db_member, 可以从cactiverecord派生一个子类:cmemberactiverecord, 把getdbconnection的重写放在该ar的子类中。

然后模型都从该cmemberactiverecord中派生。

多数据库配置遇到的一个典型的错误是:

object configuration must be an array containing a class element

原因是配置中非$db的其他数据库没有设置class属性,添加该属性并设置其值为cdbconnection即可。

参考链接:

http://yiihaa.com/models-and-multiple-database-connections

更多关于yii相关内容感兴趣的读者可查看本站专题:《yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于yii框架的php程序设计有所帮助。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网