yii2使用多個數據庫的案例

作者:白狼 出處:http://www.manks.top/article/yii2_%E5%88%86%E5%BA%93%E5%88%86%E8%A1%A8_config本文版權歸作者,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。

關於yii2配置操作多個數據庫進行操作,文檔上面也給出了具體的配置,一個實戰性的例子,也是很簡單的,我們這裏以權限控制爲單個管理庫dbname2,業務庫dbname 爲例來看看如何配置多個數據庫。


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屬性,如果有,這裏就需要配置,如果沒有,你配置試試報不報錯j_0067.gif

還差一步,最後最後一步,也是個例子說明哦。

我們以上面的userTable爲例,如果我們用gii生成了一個model文件User.php,因爲默認配置的表是位於dbname庫的,而我們的user表是dbname2庫中的表,所以呢,我們需要修改User.php 這個model文件的tableName方法,表前面加庫名即可。

public static function tableName()
{
    return 'dbname.user';
}

有腦殘粉要問了,那那那這裏的 auth_item 等表用不用也這樣操作喃,答案當然是No啦,因爲我們這裏採用的是rbacyii2-admin配置的權限管理機制,上面的配置項其實我們都已經制定好啦。

什麼,你沒看懂,那啥啥啥配置,啥啥啥vendor\mdmsoft你的項目木有,我猜你係統的權限控制木有做好,哈哈,那就先去看看yii2搭建完美后臺並實現rbac權限控制這邊文章,然後再回過頭來試試看。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章