您好,登錄后才能下訂單哦!
yii2如何在多個數據庫中使用?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
No1. 第一步,我們參照大部分百度的文檔進行操作即可。
'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 選項增加四個權限關聯的數據表的配置。
'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類的四個屬性,這里理應向上面一致,直接更改項目配置文件。
No3.到這里其實就差不多了,那有同學疑問了,我這還沒看呢,怎么就結束了呢?那那那你說我這user表和menu表怎么辦?別急,我們來看看第三個步驟:
這一步也是很簡單滴,我們向下面這樣簡單配置下就ok了
找到你項目的config\params.php文件,添加下面的配置項就好
'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'; }
看完上述內容,你們掌握yii2如何在多個數據庫中使用的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。