Yii框架 多数据库、主从、读写分离
Yii是可以在配置文件里声明多个数据库连接,然后通过Yii::app()->db1,Yii::app()->db2...来访问它们,并且也实现了更高级(自动)的主从数据库功能。
最近因为一个项目的关系,要通过Yii实现动态从库的功能,即通过数据库中的配置从动态的从库中操作数据。比如从主库查出当前用户时使用的db1数据库,那么操作的相关数据就应该是db1库的,如果另一用户是db2那么操作的就是db2库的数据,如此来实现主从库的功能。简单的可以叫做分库拆表。
实现方法:
1. 在主配置文件 (main.php) 中配置多个数据库连接:

注意,第二个以后的db数组中一定要写上class参数,让Yii 知道你在定义一个数据库连接对象,不然会报错。
一旦我们这样定义以后,就可以通过Yii::app()->db2 来指向第二个数据库了。
2. 根据配置动态的重载 GetDbConnection() 方法
因为每个Model都是(直接或者间接地)继承自基类CActiveRecord的,因此,都包含GetDbConnection()这个方法,GetDbConnection()返回一个数据库连接对象的句柄。我们需要在模型(model)里面通过重载这个方法来返回我们需要的数据库对象。
然后,假设我们新建了一文件 : protected/components/MyActiveRecord.php ,然后在你的所有要用db2这个数据库的model里extend MyActiveRecord 而不是 CActiveRecord 。
这里我们是通过扩展Yii通用类来定义一个新的类,而不是在每个模型里面都重载 getDbConnection 方法,这样做的好处是更大程度上的代码重用,节省时间。
/ protected/components/MyActiveRecord.php
class MyActiveRecord extends CActiveRecord { public function getDbConnection()
{
if(self::$db!==null)
return self::$db;
else
{
//这里就是我们要修改的
self::$db=Yii::app()->getComponent('db2');
//self::$db=Yii::app()->db2;
if(self::$db instanceof CDbConnection)
return self::$db;
else
throw new CDbException(Yii::t('yii','Active Record requires a "db2" CDbConnection application component.'));
}
}
...........
}
3. 通过Gii生成Model的时候使用新的ActiveRecord类
// protected/models/Ad.php
class Ad extends MyActiveRecord {
...
}
如此继承的类都会根据配置动态的操作对应数据库的数据了。
参考:
http://ihacklog.com/post/how-to-connect-to-two-or-more-databases-simutaneously.html
http://www.yiiframework.com/wiki/78/multiple-databases-and-multiple-domains/
http://www.yiiframework.com/wiki/123/multiple-database-support-in-yii/
更多:http://lostphp.com/blog/648.html
Yii框架 多数据库、主从、读写分离的更多相关文章
- 基于 EntityFramework 的数据库主从读写分离架构(1) - 原理概述和基本功能实现
		回到目录,完整代码请查看(https://github.com/cjw0511/NDF.Infrastructure)中的目录: src\ NDF.Data.EntityFramew ... 
- 基于 EntityFramework 的数据库主从读写分离服务插件
		基于 EntityFramework 的数据库主从读写分离服务插件 1. 版本信息和源码 1.1 版本信息 v1.01 beta(2015-04-07),基于 EF 6.1 开发,支持 EF 6.1 ... 
- 基于 EntityFramework 的数据库主从读写分离架构 - 目录
		基于 EntityFramework 的数据库主从读写分离架构 回到目录,完整代码请查看(https://github.com/cjw0511/NDF.Infrastructure)中的目 ... 
- 基于 EntityFramework 的数据库主从读写分离架构(2)- 改进配置和添加事务支持
		回到目录,完整代码请查看(https://github.com/cjw0511/NDF.Infrastructure)中的目录: src\ NDF.Data.EntityFramew ... 
- 基于 EntityFramework 的数据库主从读写分离
		现在刚开始来研究EntityFramwork,起初是在vs2012中通过工具来创建EF ,但是对我这种不熟悉菜鸟来说 有很多业务用EF做出来还是有点难度的,今天来手动搭建一个EF框架,大神勿喷 
- MySQL搭建主从数据库 实现读写分离
		首先声明,实际生产中,网站为了提高用户体验,性能等,将数据库实现读写分离是有必要的,我们让主数据库去写入数据,然后当用户查询的时候,然后在从数据库读取数据,故能减轻数据库的压力,实现良好的用户体验! ... 
- Amoeba搞定mysql主从读写分离
		前言:一直想找一个工具,能很好的实现mysql主从的读写分离架构,曾经试用过mysql-proxy发现lua用起来很不爽,尤其是不懂lua脚本,突然发现了Amoeba这个项目,试用了下,感觉还不错,写 ... 
- Amoeba实现mysql主从读写分离
		Amoeba实现mysql主从读写分离 这段在网上看了下关于amoeba的文章,总体感觉好像要比mysql-proxy好的多,也参考了不少的资料,此文章可能与其他文章作者会有雷同的地方,请谅解,但是此 ... 
- CRL快速开发框架4.4版发布,支持主从读写分离
		经过一些调整和优化,4.3已经运行在生产环境,对于不久将会遇到的查询性能,读写分离需求列上日程 读写分离需求 对于一个数据库作了主从发布/订阅,主库为DB1,从库为DB2 所有写入通过DB1,所有查询 ... 
- Mycat - 实现数据库的读写分离与高可用
		前言 开心一刻 上语文课,不小心睡着了,坐在边上的同桌突然叫醒了我,并小声说道:“读课文第三段”.我立马起身大声读了起来.正在黑板写字的老师吓了一跳,老师郁闷的看着我,问道:“同学有什么问题吗?”,我 ... 
随机推荐
- spring aop 如何切面到mvc 的controller--转载
			原文:http://yjian84.iteye.com/blog/1920787 网上搜罗半天,不知道什么原因,看了源码,好像他们说的controller 是不受代理的,也对哈,不知道怎么办,于是在h ... 
- android反编译经验谈
			反编译这事,找对了工具其实非常简单. 反编译工具下载地址http://pan.baidu.com/s/1eQvshwu android的反编译要经过两个步骤: 1.把dex文件转为jar 2.jar转 ... 
- Android(java)学习笔记205:网易新闻RSS客户端应用编写逻辑过程
			1.我们的项目需求是编写一个新闻RSS浏览器,RSS(Really Simple Syndication)是一种描述和同步网站内容的格式,是使用最广泛的XML应用.RSS目前广泛用于网上新闻频道,bl ... 
- Java——(二)Java集合容器
			------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 一.基本概念 1)Collection:一个独立元素的序列,这些元素都服从一条或多条规则.Lis ... 
- VNC服务端自动化配置脚本
			在使用阿里云的linux云主机,看到官方提供的远程连接服务器bash脚本,记录下来. 功能:自动修改系统源和安装vncserver相关的软件包,centos.redhat系列都是安装gno ... 
- oracle 字符串切割成结果集方法
			oracle字符串切割几种方式 方法一: SELECT COLUMN_VALUE FROM TABLE(SYS.ODCIVARCHAR2LIST('1','2','3','4','5')); 方法二: ... 
- window.showModalDialog()复制内容
			ShowModalDialog 打开的 页面上加入个 <span id="mySpan" name="mySpan" contentEditable=&q ... 
- Linux下sqlite的安装与使用
			简介 SQLite是一款轻量级数据库,是遵守ACID的关联式数据库管理系统.它的设计目的是嵌入式.目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百KB的内存就 ... 
- 后台线程,优先级,sleep,yield
			1.后台线程,是指在程序运行的时候在后台提供一种通用服务的线程,并且这种线程并不属于程序中不可获取的部分.当所有非后台线程结束时,程序也就 终止了,同时会杀死进程中所有后台线程.main()是一个非后 ... 
- 安卓学习之ListView和GridView
			ListView 和 GridView是安卓中显示信息的两个很基本也最常用的控件.他们的用法很相似,但是他俩也是有区别的. ListView显示的数据会将他的item放在一行显示,而且根据内容给出it ... 
