| 
 | 
 
 
            本文实例讲述了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程序设计有所帮助。 
             
             
您可能感兴趣的文章:解析yii数据库的增删查改Yii操作数据库的3种方法Yii实现MySQL多数据库和读写分离实例分析Yii实现多数据库主从读写分离的方法Yii2.0高级框架数据库增删改查的一些操作yii数据库的查询方法YII2数据库查询实践Yii框架连接mongodb数据库的代码Yii2框架数据库简单的增删改查语法小结yii2.0数据库迁移教程【多个数据库同时同步数据】 
         |   
 
 
 
 |