首頁 後端開發 php教程 如何解決ThinkPHP實作多資料庫連線的方法

如何解決ThinkPHP實作多資料庫連線的方法

Jul 03, 2018 pm 05:27 PM
thinkphp 多資料庫連接 解決方法

這篇文章主要介紹了ThinkPHP實作多資料庫連線的解決方法,需要的朋友可以參考下

ThinkPHP實作連接多個資料的時候,如果資料庫在同一個伺服器裡的話只需要這樣定義模型:

class MembersModel extends Model{
protected $trueTableName = 'members.members'; //数据库名.表名(包含了前缀)
}
登入後複製

然後就可以像D("Members");這樣實例化模型,像普通模型一樣操作了。
但後來發現他的資料庫在兩個不同的伺服器,這樣上面的方法就不行了。
這時候就需要使用TP的多重資料連線特性了。

對此,查閱官方文件進行測試並修正之後得出如下的解決方法:

要建立多數據連接,首先要建構資料庫配置參數。但是如果每次都在建立多資料庫連線的時候都建立資料庫配置數組,這樣就會很麻煩,那麼不如寫在設定檔裡。這裡怎麼寫還是需要有點技巧的。

<?php
$config= array(
&#39;DEBUG_MODE&#39;=>true,
&#39;default_module&#39;=>&#39;Index&#39;,
&#39;ROUTER_ON&#39;=>TRUE,
&#39;DATA_RESULT_TYPE&#39;=>1,
&#39;SHOW_RUN_TIME&#39;=>true,   // 运行时间显示
&#39;SHOW_ADV_TIME&#39;=>true,   // 显示详细的运行时间
&#39;SHOW_DB_TIMES&#39;=>true,   // 显示数据库查询和写入次数
&#39;SHOW_CACHE_TIMES&#39;=>true,  // 显示缓存操作次数
&#39;SHOW_USE_MEM&#39;=>true,   // 显示内存开销
&#39;HTML_FILE_SUFFIX&#39;=>&#39;.shtml&#39;,  // 默认静态文件后缀
&#39;HTML_CACHE_ON&#39; =>false,   // 默认关闭静态缓存
&#39;HTML_CACHE_TIME&#39;=>60,   // 静态缓存有效期
&#39;HTML_READ_TYPE&#39;=>1,   // 静态缓存读取方式 0 readfile 1 redirect
&#39;HTML_URL_SUFFIX&#39;=>&#39;.shtml&#39;, // 伪静态后缀设置
//默认数据库链接
&#39;DB_TYPE&#39;=>&#39;mysql&#39;,
&#39;DB_HOST&#39;=>&#39;localhost&#39;,
&#39;DB_NAME&#39;=>&#39;news&#39;,
&#39;DB_USER&#39;=>&#39;root&#39;,
&#39;DB_PWD&#39;=>&#39;123&#39;,
&#39;DB_PORT&#39;=>&#39;3306&#39;,
&#39;DB_PREFIX&#39;=>&#39;news_&#39;,
//我的第一个数据库连接
&#39;DB_BBS&#39;=>array(
&#39;dbms&#39; => &#39;mysql&#39;,
&#39;username&#39; => &#39;discuz&#39;,
&#39;password&#39; => &#39;123&#39;,
&#39;hostname&#39; => &#39;localhost&#39;,
&#39;hostport&#39; => &#39;3306&#39;,
&#39;database&#39; => &#39;discuz&#39;
),
//第二个数据库链接,
&#39;DB_NEWS&#39;=>array(
&#39;dbms&#39;=>&#39;mysql&#39;,
&#39;username&#39;=>&#39;root&#39;,
&#39;password&#39;=>&#39;123&#39;,
&#39;hostname&#39;=>&#39;localhost&#39;,
&#39;hostport&#39;=>&#39;3306&#39;,
&#39;database&#39;=>&#39;news&#39;
)
);
return $config;
?>
登入後複製

#到此我們就可以用C("DB_BBS")和C("DB_NEWS")來得到資料庫的設定數組。
配置好了,現在需要實例化模型。因為我們這個模型需要使用兩個不同的資料庫的連接,項目的設定檔裡預設了個資料庫配置,如果你建立了某個表格的模型例如UserModel.class.php,
如果你用D(" User");但假如目前預設的資料庫裡沒User個表的話就會報錯。所以我們要建立個空模型。空模型是不會選表的。
有兩種方法建立空模型。 $dao=D();和$dao=new Model();都可以。

$dao=D();
登入後複製

實例化模型後,我們需要增加資料庫模型;

$dao->addConnect(C("DB_BBS"),1,true);
$dao->addConnect(C("DB_NEWS"),2,true);
登入後複製

##說一下這個addConnect();這個函數的原型在1.0.3和1.0.4是有差別的。

在1.0.3的原型是:

boolean addConnect (mixed $config, mixed $linkNum, [boolean $eqType = true])
登入後複製

在1.0.4的原型是:


boolean addConnect (mixed $config, mixed $linkNum)
登入後複製

少了第三個參數。

第一個參數是資料庫的配置數組,第二個參數是新增的連接的編號,這個編號在切換資料庫連接的時候需要給出是那個序號的連接。注意
內建的資料庫連接序號是0,所以額外的資料庫連接序號應該從1開始.第三個參數是如果兩個資料庫是否是相同的連接,是就是true;

#新增完資料庫連線後,就可以隨時切換資料庫連線了。例如我們這要用DB_NEWS這個資料庫,就這麼寫:

$dao->switchConnect(2);
登入後複製
登入後複製

因為這裡只是建立了資料庫的連接,並沒有選表,所以接下來需要選表。

注意這裡的表名是全名,即表的前綴加表名。因為我們在連接資料庫的設定數組裡沒前綴。我覺得應該可以定義,但我不知道。現在就這樣了。

$dao->table("cdb_members");
登入後複製

之後就可以像普通模型一樣的用這個模型了。

例如我要查詢傳遞過來的ID的使用者的所有資訊 :

$map=array("id"=>$_GET["id"]);
$res=$dao->find($map);
登入後複製

可以看看查詢是否成功了。

dump($res);
登入後複製

如果你現在要用DB_BBS的資料庫的表,只要再切換一次連線;

$dao->switchConnect(2);
登入後複製
登入後複製

然後再選表格查詢。記住,切換模型後一定要再選一次表,不然會出錯。

之後又可以像普通模型那樣操作了。
下面針對手冊指出裡面存在的幾個問題:

1.實例化多資料庫連線的時候建立了個非空的模型。 (好像還寫錯了。)這樣可能會出錯。建議建立空模型;

2.addConnect()的參數在不同的版本是不同的,手冊中沒寫出來;
3.建立了空模型後需要選表,這個手冊裡沒有。

針對以上幾點,ThinkPHP使用者可以根據版本的不同酌情進行相應的調整。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

ThinkPHP實作ajax仿官網搜尋的功能

php float不四捨五入截取浮點型字符字串的方法

#

以上是如何解決ThinkPHP實作多資料庫連線的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
公司安全軟件導致應用無法運行?如何排查和解決? 公司安全軟件導致應用無法運行?如何排查和解決? Apr 19, 2025 pm 04:51 PM

公司安全軟件導致部分應用無法正常運行的排查與解決方法許多公司為了保障內部網絡安全,會部署安全軟件。 ...

centos minio安裝權限問題 centos minio安裝權限問題 Apr 14, 2025 pm 02:00 PM

CentOS系統下MinIO安裝的權限問題及解決方案在CentOS環境部署MinIO時,權限問題是常見難題。本文將介紹幾種常見的權限問題及其解決方法,助您順利完成MinIO安裝與配置。修改默認賬戶及密碼:您可以通過設置環境變量MINIO_ROOT_USER和MINIO_ROOT_PASSWORD來修改默認的用戶名和密碼。修改後,重啟MinIO服務即可生效。配置存儲桶訪問權限:將存儲桶設置為公開(public)會導致目錄可被遍歷,存在安全風險。建議自定義存儲桶訪問策略。您可以通過MinIO

PHP如何使用phpMyadmin創建Mysql數據庫 PHP如何使用phpMyadmin創建Mysql數據庫 Apr 10, 2025 pm 10:48 PM

phpMyAdmin 可用於在 PHP 項目中創建數據庫。具體步驟如下:登錄 phpMyAdmin,點擊“新建”按鈕。輸入要創建的數據庫的名稱,注意符合 MySQL 命名規則。設置字符集,如 UTF-8,以避免亂碼問題。

Navicat 無法連接數據庫的解決方法 Navicat 無法連接數據庫的解決方法 Apr 08, 2025 pm 11:12 PM

可以通過以下步驟解決 Navicat 無法連接數據庫的問題:檢查服務器連接,確保服務器運行、地址和端口正確,防火牆允許連接。驗證登錄信息,確認用戶名、密碼和權限正確。檢查網絡連接,排除網絡問題,例如路由器或防火牆故障。禁用 SSL 連接,某些服務器可能不支持。檢查數據庫版本,確保 Navicat 版本與目標數據庫兼容。調整連接超時,對於遠程或較慢的連接,增加連接超時時間。其他解決方法,如果上述步驟無效,可以嘗試重新啟動軟件,使用不同的連接驅動程序,或諮詢數據庫管理員或 Navicat 官方支持。

Redis內存使用率過高怎麼辦? Redis內存使用率過高怎麼辦? Apr 10, 2025 pm 02:21 PM

Redis內存飆升的原因包括:數據量過大、數據結構選擇不當、配置問題(如maxmemory設置過小)、內存洩漏。解決方法有:刪除過期數據、使用壓縮技術、選擇合適的結構、調整配置參數、檢查代碼是否存在內存洩漏、定期監控內存使用情況。

CentOS HDFS配置有哪些常見誤區 CentOS HDFS配置有哪些常見誤區 Apr 14, 2025 pm 07:12 PM

CentOS下Hadoop分佈式文件系統(HDFS)配置常見問題及解決方案在CentOS系統上搭建HadoopHDFS集群時,一些常見的錯誤配置可能導致性能下降、數據丟失甚至集群無法啟動。本文總結了這些常見問題及其解決方法,幫助您避免這些陷阱,確保HDFS集群的穩定性和高效運行。機架感知配置錯誤:問題:未正確配置機架感知信息,導致數據塊副本分佈不均,增加網絡負載。解決方案:仔細檢查hdfs-site.xml文件中的機架感知配置,並使用hdfsdfsadmin-printTopo

vs code 可以在 Windows 8 中運行嗎 vs code 可以在 Windows 8 中運行嗎 Apr 15, 2025 pm 07:24 PM

VS Code可以在Windows 8上運行,但體驗可能不佳。首先確保系統已更新到最新補丁,然後下載與系統架構匹配的VS Code安裝包,按照提示安裝。安裝後,注意某些擴展程序可能與Windows 8不兼容,需要尋找替代擴展或在虛擬機中使用更新的Windows系統。安裝必要的擴展,檢查是否正常工作。儘管VS Code在Windows 8上可行,但建議升級到更新的Windows系統以獲得更好的開發體驗和安全保障。

laravel和thinkphp的區別 laravel和thinkphp的區別 Apr 18, 2025 pm 01:09 PM

Laravel 和 ThinkPHP 都是流行的 PHP 框架,在開發中各有優缺點。本文將深入比較這兩者,重點介紹它們的架構、特性和性能差異,以幫助開發者根據其特定項目需求做出明智的選擇。

See all articles