相關(guān)關(guān)鍵詞
關(guān)于我們
最新文章
- PHP中opcode緩存簡單用法分析
- thinkPHP控制器變量在模板中的顯示方法示例
- PHP move_uploaded_file() 函數(shù)(將上傳的文件移動(dòng)到新位置)
- dirname(__FILE__)的含義和應(yīng)用說明
- thinkPHP5框架實(shí)現(xiàn)分頁查詢功能的方法示例
- PHP中單雙號(hào)與變量
- PHP獲得當(dāng)日零點(diǎn)時(shí)間戳的方法分析
- Laravel ORM對(duì)Model::find方法進(jìn)行緩存示例詳解
- PHP讀寫文件高并發(fā)處理操作實(shí)例詳解
- 【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的實(shí)現(xiàn)
詳解yii2實(shí)現(xiàn)分庫分表的方案與思路
前言
大家可以從任何一個(gè)gii生成model類開始代碼上溯,會(huì)發(fā)現(xiàn):yii2的model層基于ActiveRecord實(shí)現(xiàn)DAO訪問數(shù)據(jù)庫的能力。
而ActiveRecord的繼承鏈可以繼續(xù)上溯,最終會(huì)發(fā)現(xiàn)model其實(shí)是一個(gè)component,而component是yii2做IOC的重要組成部分,提供了behaviors,event的能力供繼承者擴(kuò)展。
(IOC,component,behaviors,event等概念可以參考http://www.digpage.com/學(xué)習(xí))
先不考慮上面的一堆概念,一個(gè)站點(diǎn)發(fā)展歷程一般是1個(gè)庫1個(gè)表,1個(gè)庫N個(gè)表,M個(gè)庫N個(gè)表這樣走過來的,下面拿訂單表為例,分別說說。
1)1庫1表:yii2默認(rèn)采用PDO連接mysql,框架默認(rèn)會(huì)配置一個(gè)叫做db的component作為唯一的mysql連接對(duì)象,其中dsn分配了數(shù)據(jù)庫地址,數(shù)據(jù)庫名稱,配置如下:
'components' => [ 'db' => [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=10.10.10.10;port=4005;dbname=wordpress', 'username' => 'wp', 'password' => '123', 'charset' => 'utf8', ],