詳解yii2使用多個(gè)數(shù)據(jù)庫(kù)的案例
關(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類(lèi)的四個(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ò)
還差一步,最后最后一步,也是個(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)槲覀冞@里采用的是rbac和yii2-admin配置的權(quán)限管理機(jī)制,上面的配置項(xiàng)其實(shí)我們都已經(jīng)制定好啦。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
thinkPHP5框架數(shù)據(jù)庫(kù)連貫操作之cache()用法分析
這篇文章主要介紹了thinkPHP5框架數(shù)據(jù)庫(kù)連貫操作之cache()用法,結(jié)合實(shí)例形式分析了thinkPHP5中緩存cache的應(yīng)用場(chǎng)景及連貫操作中cache的設(shè)置、更新、刪除等操作技巧,需要的朋友可以參考下2018-01-01php中實(shí)現(xiàn)用數(shù)組嫵媚地生成要執(zhí)行的sql語(yǔ)句
這篇文章主要介紹了php中實(shí)現(xiàn)用數(shù)組嫵媚地生成要執(zhí)行的sql語(yǔ)句,本文直接給出代碼示例,需要的朋友可以參考下2015-07-07Thinkphp通過(guò)一個(gè)入口文件如何區(qū)分移動(dòng)端和PC端
這篇文章主要介紹了Thinkphp通過(guò)一個(gè)入口文件區(qū)分移動(dòng)端和PC端的方法,需要的的朋友參考下吧2017-04-04- 使用COM,可以在PHP中控制Excel。下面通過(guò)一個(gè)簡(jiǎn)單的示例來(lái)演示PHP如何與Excel相交互(示例中有詳細(xì)的注釋?zhuān)?/div> 2010-04-04
php文件服務(wù)實(shí)現(xiàn)虛擬掛載其他目錄示例
這篇文章主要介紹了php文件服務(wù)實(shí)現(xiàn)虛擬掛載其他目錄示例,需要的朋友可以參考下2014-04-04php實(shí)現(xiàn)window平臺(tái)的checkdnsrr函數(shù)
這篇文章主要介紹了php實(shí)現(xiàn)window平臺(tái)的checkdnsrr函數(shù),PHP的自帶checkdnsrr函數(shù)只在linux平臺(tái)有效,本文就模擬出了一個(gè)window下可以使用的checkdnsrr函數(shù),需要的朋友可以參考下2015-05-05Laravel自定義 封裝便捷返回Json數(shù)據(jù)格式的引用方法
今天小編就為大家分享一篇Laravel自定義 封裝便捷返回Json數(shù)據(jù)格式的引用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09寶塔 php修改了php.ini配置不生效的問(wèn)題及解決方法
最近在使用hypref,php的版本是7.4,服務(wù)器linux,用寶塔安裝完php,并裝完swoole插件后,安裝了swoole后,需要在php.ini中修改一下配置文件,本文給大家分享寶塔 php修改了php.ini配置不生效的問(wèn)題及解決方法,感興趣的朋友一起看看吧2023-09-09最新評(píng)論