做者:白狼php
出處:http://www.manks.top/article/yii2_%E5%88%86%E5%BA%93%E5%88%86%E8%A1%A8_configmysql
本文版權歸做者,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,不然保留追究法律責任的權利。sql
關於yii2配置操做多個數據庫進行操做,文檔上面也給出了具體的配置,一個實戰性的例子,也是很簡單的,咱們這裏以權限控制爲單個管理庫dbname2,業務庫dbname
爲例來看看如何配置多個數據庫。數據庫
No1. 第一步,咱們參照大部分百度的文檔進行操做便可。yii2
'components' => [ 'db' => [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=ip;dbname=dbname', 'username' => 'username', 'password' => 'pwd', 'charset' => 'utf8', ], 'db2' => [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=ip;dbname=dbname2', 'username' => 'username', 'password' => 'pwd', 'charset' => 'utf8', ], ],
No2.第二步,這裏咱們打開配置文件 main.php
,對 authManager
選項增長四個權限關聯的數據表的配置。yii
'authManager' => [ 'class' => 'yii\rbac\DbManager', 'defaultRoles' => ['guest'], 'itemTable' => 'dbname2.auth_item', 'itemChildTable' => 'dbname2.auth_item_child', 'assignmentTable' => 'dbname2.auth_assignment', 'ruleTable' => 'dbname2.auth_rule', ],
其實這裏配置的是 vendor\yiisoft\yii2\rbac\DbManager.php
類的四個屬性,這裏理應向上面一致,直接更改項目配置文件。spa
No3.到這裏其實就差很少了,那有同窗疑問了,我這還沒看呢,怎麼就結束了呢?那那那你說我這user
表和menu
表怎麼辦?別急,咱們來看看第三個步驟:code
這一步也是很簡單滴,咱們向下面這樣簡單配置下就ok了component
找到你項目的config\params.php
文件,添加下面的配置項就好orm
'mdm.admin.configs' => [ 'menuTable' => 'dbname2.menu', // 'userTable' => 'dbname2.user', ],
注意啦,上面這個爲啥配置項 userTable屏蔽了呢,這個要看我的的配置,打開文件 vendor\mdmsoft\yii2-admin\components\Configs.php
文件,查看下有沒有userTable
屬性,若是有,這裏就須要配置,若是沒有,你配置試試報不報錯
還差一步,最後最後一步,也是個例子說明哦。
咱們以上面的userTable
爲例,若是咱們用gii
生成了一個model
文件User.php
,由於默認配置的表是位於dbname
庫的,而咱們的user
表是dbname2
庫中的表,因此呢,咱們須要修改User.php
這個model
文件的tableName
方法,表前面加庫名便可。
public static function tableName() { return 'dbname.user'; }
有腦殘粉要問了,那那那這裏的 auth_item
等表用不用也這樣操做喃,答案固然是No啦,由於咱們這裏採用的是rbac
和yii2-admin
配置的權限管理機制,上面的配置項其實咱們都已經制定好啦。
什麼,你沒看懂,那啥啥啥配置,啥啥啥vendor\mdmsoft
你的項目木有,我猜你係統的權限控制木有作好,哈哈,那就先去看看《yii2搭建完美后臺並實現rbac權限控制》這邊文章,而後再回過頭來試試看。