天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ThinkPHP實現多數據庫連接的解決方法

Thinkphp實現連接多個數據的時候,如果數據庫在同一個服務器里的話只需要這樣定義模型:

class MembersModel extends Model{protected $trueTableName = 'members.members'; //數據庫名.表名(包含了前綴)}

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

對此,查閱官方文檔進行測試并修正之后得出了如下的解決方法:

要建立多數據連接,首先要構造數據庫配置參數。但是如果每次都在建立多數據庫連接的時候都建立數據庫配置數組,這樣就會很麻煩,還不如寫在配置文件里。這里怎么寫還是需要有點技巧的。

<?php$config=  array('DEBUG_MODE'=>true,'default_module'=>'Index','ROUTER_ON'=>TRUE,'DATA_RESULT_TYPE'=>1,'SHOW_RUN_TIME'=>true,      // 運行時間顯示'SHOW_ADV_TIME'=>true,      // 顯示詳細的運行時間'SHOW_DB_TIMES'=>true,      // 顯示數據庫查詢和寫入次數'SHOW_CACHE_TIMES'=>true,    // 顯示緩存操作次數'SHOW_USE_MEM'=>true,      // 顯示內存開銷'HTML_FILE_SUFFIX'=>'.shtml',   // 默認靜態文件后綴'HTML_CACHE_ON'  =>false,     // 默認關閉靜態緩存'HTML_CACHE_TIME'=>60,     // 靜態緩存有效期'HTML_READ_TYPE'=>1,      // 靜態緩存讀取方式 0 readfile 1 redirect'HTML_URL_SUFFIX'=>'.shtml',  // 偽靜態后綴設置//默認數據庫鏈接'DB_TYPE'=>'mysql','DB_HOST'=>'localhost','DB_NAME'=>'news','DB_USER'=>'root','DB_PWD'=>'123','DB_PORT'=>'3306','DB_PREFIX'=>'news_',//我的第一個數據庫連接'DB_BBS'=>array('dbms' => 'mysql','username' => 'discuz','password' => '123','hostname' => 'localhost','hostport' => '3306','database' => 'discuz'),//第二個數據庫鏈接,'DB_NEWS'=>array('dbms'=>'mysql','username'=>'root','password'=>'123','hostname'=>'localhost','hostport'=>'3306','database'=>'news'));return $config;?>

至此我們就可以用C("DB_BBS")和C("DB_NEWS")來得到數據庫的配置數組。
配置好了,現在需要實例化模型。因為我們這個模型需使用兩個不同的數據庫的連接,項目的配置文件里默認了個數據庫配置,如果你建立了某個表的模型比如UserModel.class.php
如果你用D("User");但假如當前默認的數據庫里沒User個表的話就會報錯。所以我們要建立個空模型??漳P褪遣粫x表的。
有兩種方法建立空模型。$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);

因為這里只是建立了數據庫的連接,并沒有選表,所以接下來需要選表。
注意這里的表名是全名,即表的前綴加表名。因為我們在連接數據庫的配置數組里沒前綴。我覺得應該可以定義,但我不知道?,F在就這樣了。

$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實現多數據庫連接的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 区产品乱码芒果精品P站在线 | 美女裸露胸部100%无遮挡 | 美女脱精光让男生桶下面 | JAVAPARSER丰满白老师 | 97人人超碰国产精品最新蜜芽 | 国产午夜精品理论片久久影视 | 晓雪老师我要进你里面好爽 | 永久免费观看视频 | yellow日本动漫观看免费 | 国产精品野外AV久久久 | 有人在线观看的视频吗免费 | 久久夜色撩人精品国产 | 我要干av| 中文字幕亚洲无线码一区 | 麻豆狠色伊人亚洲综合网站 | 久久精品国产色蜜蜜麻豆国语版 | 中文字幕无线观看不卡网站 | ca88亚洲城娱乐 | adc影院欢迎您大驾光临入口 | 久久国产精品无码视欧美 | 精品日韩视频 | 国产专区亚洲欧美另类在线 | 国产亚洲精品AAAAAAA片 | 国产无线乱码一区二三区 | 亚洲色tu| 99久久免费精品 | 国产成人国产在线观看入口 | 日韩视频中文字幕精品偷拍 | 国产精品久久久久久久久久影院 | 久久人妻少妇嫩草AV无码 | 在线免费观看毛片网站 | 国语大学生自产拍在线观看 | 黑丝女仆恋上我 | 神马电影我不卡4k手机在线观看 | 狠狠色香婷婷久久亚洲精品 | 99精品热视频30在线热视频 | 国产视频a在线观看v | 国产电影无码午夜在线播放 | 俄罗斯美女破处 | 黄色a三级三级三级免费看 黄色a三级免费看 | 性色香蕉AV久久久天天网 |