首頁  >  文章  >  後端開發  >  yii2使用多個資料庫執行個體方法

yii2使用多個資料庫執行個體方法

小云云
小云云原創
2018-02-12 14:31:561785瀏覽

關於yii2配置操作多個資料庫進行操作,文檔上面也給了具體的配置,一個實戰性的例子,也是很簡單的,我們這裡以權限控制為單一管理庫dbname2,業務庫dbname 為例來看看如何配置多個資料庫。本文主要和大家介紹了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';
}

相關推薦:

php中CI操作多個資料庫的程式碼

php如何同時連接多個資料庫_PHP教學

PHP 怎麼寫多個資料庫之間查詢的語句

#

以上是yii2使用多個資料庫執行個體方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn