詳解yii2使用多個資料庫的案例

NO IMAGE

關於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屬性,如果有,這裡就需要配置,如果沒有,你配置試試報不報錯

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

我們以上面的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配置的許可權管理機制,上面的配置項其實我們都已經制定好啦。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援指令碼之家。

您可能感興趣的文章:

Yii框架實現多資料庫配置和操作的方法Yii實現多資料庫主從讀寫分離的方法Yii實現MySQL多資料庫和讀寫分離例項分析