ThinkPHP3.1新特性之多數(shù)據(jù)庫(kù)操作更加完善
通常情況下,如果一個(gè)應(yīng)用只是操作同一個(gè)數(shù)據(jù)庫(kù)(或者分布式數(shù)據(jù)庫(kù))的話,你只需要在項(xiàng)目配置文件中定義數(shù)據(jù)庫(kù)連接信息即可。這里說的多數(shù)據(jù)庫(kù)操作一般指的是在一個(gè)應(yīng)用中會(huì)操作不同的數(shù)據(jù)庫(kù)(包括同類型的和不同類型的數(shù)據(jù)庫(kù)),甚至包括動(dòng)態(tài)切換多數(shù)據(jù)庫(kù)的情況。
對(duì)于早期版本的ThinkPHP來說,切換數(shù)據(jù)庫(kù)需要使用高級(jí)模型,而現(xiàn)在的3.1版本則可以更加輕松的解決了。
新版對(duì)多數(shù)據(jù)的支持有下面幾種方式,開發(fā)人員可以根據(jù)實(shí)際情況選擇合適的方式操作:
1.模型定義數(shù)據(jù)庫(kù)
如果只是簡(jiǎn)單的跨庫(kù)操作,并且只是個(gè)別模型類的話,你可以直接在模型類中定義dbName屬性即可:
protected $dbName = 'top';
實(shí)例化的時(shí)候,記得要使用D方法,例如:
$User = D('User');
這種方式定義的前提是當(dāng)前數(shù)據(jù)庫(kù)用戶賬戶有操作top數(shù)據(jù)庫(kù)的權(quán)限。
2.模型定義數(shù)據(jù)庫(kù)連接
如果你的跨庫(kù)操作需要使用不同的數(shù)據(jù)庫(kù)連接賬號(hào)或者需要連接不同類型的數(shù)據(jù)庫(kù),可以直接在模型類里面定義connection屬性,在操作該模型類的時(shí)候,就會(huì)自動(dòng)連接到指定的數(shù)據(jù)庫(kù)。例如:
protected $connection = 'mysql://root:1234@localhost:3306/thinkphp';
或者使用數(shù)組方式定義:
protected $connection = array( 'db_type' => 'mysql', 'db_user' => 'root', 'db_pwd' => '1234', 'db_host' => 'localhost', 'db_port' => '3306', 'db_name' => 'thinkphp' );
如果我們已經(jīng)在配置文件中配置了額外的數(shù)據(jù)庫(kù)連接信息,例如:
//數(shù)據(jù)庫(kù)配置1 'DB_CONFIG1' = array( 'db_type' => 'mysql', 'db_user' => 'root', 'db_pwd' => '1234', 'db_host' => 'localhost', 'db_port' => '3306', 'db_name' => 'thinkphp' ), //數(shù)據(jù)庫(kù)配置2 'DB_CONFIG2' => 'mysql://root:1234@localhost:3306/thinkphp';
那么,我們可以把模型類的屬性定義改為:
//調(diào)用配置文件中的數(shù)據(jù)庫(kù)配置1 protected $connection = 'DB_CONFIG1';
或者:
//調(diào)用配置文件中的數(shù)據(jù)庫(kù)配置2 protected $connection = 'DB_CONFIG2';
這種方式的優(yōu)點(diǎn)可以支持不同數(shù)據(jù)庫(kù)類型,也就是說可以和當(dāng)前的項(xiàng)目配置文件中的數(shù)據(jù)庫(kù)類型不同,缺點(diǎn)是必須使用D方法實(shí)例化,而且不能動(dòng)態(tài)設(shè)定。
3.模型實(shí)例化指定連接
新版支持在實(shí)例化模型的時(shí)候指定數(shù)據(jù)庫(kù)連接,例如:
$User = new Model('User','think_','mysql://root:1234@localhost/thinkphp');
或者使用M方法實(shí)例化:
$User = M('User','think_','mysql://root:1234@localhost/thinkphp');
M方法的第二個(gè)參數(shù)是數(shù)據(jù)表的前綴,如果留空表示采用項(xiàng)目配置的數(shù)據(jù)表前綴,第三個(gè)參數(shù)則是當(dāng)前實(shí)例化需要的數(shù)據(jù)庫(kù)連接信息。
同樣的道理,在實(shí)例化中傳入的數(shù)據(jù)庫(kù)連接信息也可以采用配置名稱的方式,例如:
$User = M('User','think_','DB_CONFIG2');
如果當(dāng)前操作不需要切換數(shù)據(jù)庫(kù)連接,只是需要切換數(shù)據(jù)庫(kù),則可以采用:
$User = M('top.User','think_');
表示實(shí)例化top數(shù)據(jù)庫(kù)的think_user數(shù)據(jù)表。如果你的數(shù)據(jù)表沒有前綴,可以使用
$User = M('top.User',null);
表示實(shí)例化top數(shù)據(jù)庫(kù)的user表。
4.動(dòng)態(tài)切換連接
系統(tǒng)還提供了更靈活的動(dòng)態(tài)操作,可以使用模型類提供的db方法進(jìn)行多數(shù)據(jù)庫(kù)連接和切換操作,用法:
Model->db("數(shù)據(jù)庫(kù)編號(hào)","數(shù)據(jù)庫(kù)配置");
數(shù)據(jù)庫(kù)編號(hào)用數(shù)字格式,對(duì)于已經(jīng)調(diào)用過的數(shù)據(jù)庫(kù)連接,是不需要再傳入數(shù)據(jù)庫(kù)連接信息的,系統(tǒng)會(huì)自動(dòng)記錄。對(duì)于初始化的數(shù)據(jù)庫(kù)連接,內(nèi)部的數(shù)據(jù)庫(kù)編號(hào)是0,因此為了避免沖突,請(qǐng)不要再次定義數(shù)據(jù)庫(kù)編號(hào)為0的數(shù)據(jù)庫(kù)配置。
數(shù)據(jù)庫(kù)配置的定義方式和模型定義connection屬性一樣,支持?jǐn)?shù)組、字符串以及調(diào)用配置參數(shù)三種格式。
Db方法調(diào)用后返回當(dāng)前的模型實(shí)例,直接可以繼續(xù)進(jìn)行模型的其他操作,所以該方法可以在查詢的過程中動(dòng)態(tài)切換,例如:
$this->db(1,"mysql://root:123456@localhost:3306/test")->query("查詢SQL");
該方法添加了一個(gè)編號(hào)為1的數(shù)據(jù)庫(kù)連接,并自動(dòng)切換到當(dāng)前的數(shù)據(jù)庫(kù)連接。
當(dāng)?shù)诙吻袚Q到相同的數(shù)據(jù)庫(kù)的時(shí)候,就不需要傳入數(shù)據(jù)庫(kù)連接信息了,可以直接使用:
$this->db(1)->query("查詢SQL");
在沒有再次進(jìn)行數(shù)據(jù)庫(kù)切換之前,當(dāng)前的所有操作都是針對(duì)db(1)所設(shè)置的數(shù)據(jù)庫(kù)。
如果需要切換到默認(rèn)的數(shù)據(jù)庫(kù)連接,只需要調(diào)用:
$this->db(0);
如果我們已經(jīng)在項(xiàng)目配置中定義了其他的數(shù)據(jù)庫(kù)連接信息,我們就可以直接在db方法中調(diào)用配置進(jìn)行連接了:
$this->db(1,"DB_CONFIG1")->query("查詢SQL"); $this->db(2,"DB_CONFIG2")->query("查詢SQL");
如果切換數(shù)據(jù)庫(kù)之后,數(shù)據(jù)表和當(dāng)前不一致的話,可以使用table方法指定要操作的數(shù)據(jù)表:
$this->db(1)->table("top_user")->find();
如果要返回當(dāng)前的數(shù)據(jù)庫(kù)連接,可以直接調(diào)用空的db方法即可,例如:
$db = $this->db();
- ThinkPHP實(shí)現(xiàn)多數(shù)據(jù)庫(kù)連接的解決方法
- tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)查詢的方法
- Thinkphp使用mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)多條件查詢方法
- thinkPHP5框架實(shí)現(xiàn)多數(shù)據(jù)庫(kù)連接,跨數(shù)據(jù)連接查詢操作示例
- ThinkPHP5.0框架實(shí)現(xiàn)切換數(shù)據(jù)庫(kù)的方法分析
- thinkphp3.2.3版本的數(shù)據(jù)庫(kù)增刪改查實(shí)現(xiàn)代碼
- ThinkPHP連接數(shù)據(jù)庫(kù)及主從數(shù)據(jù)庫(kù)的設(shè)置教程
- thinkphp配置連接數(shù)據(jù)庫(kù)技巧
- ThinkPHP連接數(shù)據(jù)庫(kù)的方式匯總
- ThinkPHP3.2.3數(shù)據(jù)庫(kù)設(shè)置新特性
- thinkphp3.2.3框架動(dòng)態(tài)切換多數(shù)據(jù)庫(kù)的方法分析
相關(guān)文章
PHP實(shí)現(xiàn)的簡(jiǎn)單三角形、矩形周長(zhǎng)面積計(jì)算器分享
這篇文章主要介紹了PHP實(shí)現(xiàn)的簡(jiǎn)單三角形、矩形周長(zhǎng)面積計(jì)算器分享,本文的實(shí)現(xiàn)相對(duì)較簡(jiǎn)單,同時(shí)提供了代碼文件下載,需要的朋友可以參考下2014-11-11PHP中cookie和session的區(qū)別實(shí)例分析
這篇文章主要介紹了PHP中cookie和session的區(qū)別,比較詳盡的分析了二者從創(chuàng)建、運(yùn)用到清除的各個(gè)流程的注意事項(xiàng),需要的朋友可以參考下2014-08-08解析php中mysql_connect與mysql_pconncet的區(qū)別詳解
本篇文章是對(duì)php中mysql_connect與mysql_pconncet的區(qū)別進(jìn)行了分析介紹,需要的朋友參考下2013-05-05