溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

yii2使用多個(gè)數(shù)據(jù)庫(kù)的案例

發(fā)布時(shí)間:2020-08-07 08:29:44 來(lái)源:網(wǎng)絡(luò) 閱讀:371 作者:軒_LAMP 欄目:數(shù)據(jù)庫(kù)

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

關(guān)于yii2配置操作多個(gè)數(shù)據(jù)庫(kù)進(jìn)行操作,文檔上面也給出了具體的配置,一個(gè)實(shí)戰(zhàn)性的例子,也是很簡(jiǎn)單的,我們這里以權(quán)限控制為單個(gè)管理庫(kù)dbname2,業(yè)務(wù)庫(kù)dbname 為例來(lái)看看如何配置多個(gè)數(shù)據(jù)庫(kù)。


No1. 第一步,我們參照大部分百度的文檔進(jìn)行操作即可。

'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.第二步,這里我們打開(kāi)配置文件 main.php ,對(duì) authManager 選項(xiàng)增加四個(gè)權(quán)限關(guān)聯(lián)的數(shù)據(jù)表的配置。

'authManager' => [
    'class' => 'yii\rbac\DbManager',
    'defaultRoles' => ['guest'],
    'itemTable' => 'dbname2.auth_item',
    'itemChildTable' => 'dbname2.auth_item_child',
    'assignmentTable' => 'dbname2.auth_assignment',
    'ruleTable' => 'dbname2.auth_rule',
],

其實(shí)這里配置的是 vendor\yiisoft\yii2\rbac\DbManager.php類的四個(gè)屬性,這里理應(yīng)向上面一致,直接更改項(xiàng)目配置文件。

No3.到這里其實(shí)就差不多了,那有同學(xué)疑問(wèn)了,我這還沒(méi)看呢,怎么就結(jié)束了呢?那那那你說(shuō)我這user表和menu表怎么辦?別急,我們來(lái)看看第三個(gè)步驟:

這一步也是很簡(jiǎn)單滴,我們向下面這樣簡(jiǎn)單配置下就ok了

找到你項(xiàng)目的config\params.php文件,添加下面的配置項(xiàng)就好

'mdm.admin.configs' => [
    'menuTable' => 'dbname2.menu',
    // 'userTable' => 'dbname2.user',
],

注意啦,上面這個(gè)為啥配置項(xiàng) userTable屏蔽了呢,這個(gè)要看個(gè)人的配置,打開(kāi)文件 vendor\mdmsoft\yii2-admin\components\Configs.php文件,查看下有沒(méi)有userTable屬性,如果有,這里就需要配置,如果沒(méi)有,你配置試試報(bào)不報(bào)錯(cuò)yii2使用多個(gè)數(shù)據(jù)庫(kù)的案例

還差一步,最后最后一步,也是個(gè)例子說(shuō)明哦。

我們以上面的userTable為例,如果我們用gii生成了一個(gè)model文件User.php,因?yàn)槟J(rèn)配置的表是位于dbname庫(kù)的,而我們的user表是dbname2庫(kù)中的表,所以呢,我們需要修改User.php 這個(gè)model文件的tableName方法,表前面加庫(kù)名即可。

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

有腦殘粉要問(wèn)了,那那那這里的 auth_item 等表用不用也這樣操作喃,答案當(dāng)然是No啦,因?yàn)槲覀冞@里采用的是rbacyii2-admin配置的權(quán)限管理機(jī)制,上面的配置項(xiàng)其實(shí)我們都已經(jīng)制定好啦。

什么,你沒(méi)看懂,那啥啥啥配置,啥啥啥vendor\mdmsoft你的項(xiàng)目木有,我猜你系統(tǒng)的權(quán)限控制木有做好,哈哈,那就先去看看yii2搭建完美后臺(tái)并實(shí)現(xiàn)rbac權(quán)限控制這邊文章,然后再回過(guò)頭來(lái)試試看。


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI