欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-12 16:20:20
本文实例讲述了yii框架实现多数据库配置和操作的方法。分享给大家供大家参考,具体如下: yii的默认配置为一个数据库,不过可以很容易的支持多个数据库的操作, 这为按业务...

本文实例讲述了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程序设计有所帮助。