通常情況下,如果一個應用只是操作同一個資料庫(或者分散式資料庫)的話,你只需要在項目設定檔中定義資料庫連接資訊即可。這裡說的多資料庫操作一般指的是在一個應用中會操作不同的資料庫(包括同類型的和不同類型的資料庫),甚至包括動態切換多資料庫的情況。
對於早期版本的ThinkPHP來說,切換資料庫需要使用進階模型,而現在的3.1版本則可以更加輕鬆的解決了。
新版對多資料的支援有下面幾種方式,開發人員可以根據實際情況選擇合適的方式操作:
1.模型定義資料庫
如果只是簡單的跨庫操作,並且只是個別模型類的話,你可以直接在模型類中定義dbName屬性即可:
protected $dbName = 'top';
執行個體化的時候,記得要使用D方法,例如:
$User = D('User');
這種方式定義的前提是當前資料庫使用者賬戶有操作top資料庫的許可權。
2.模型定義資料庫連接
如果你的跨庫操作需要使用不同的資料庫連接帳號或者需要串連不同類型的資料庫,可以直接在模型類裡面定義connection屬性,在操作該模型類的時候,就會自動連接到指定的資料庫。例如:
protected $connection = 'mysql://root:1234@localhost:3306/thinkphp';
或者使用數組方式定義:
protected $connection = array( 'db_type' => 'mysql', 'db_user' => 'root', 'db_pwd' => '1234', 'db_host' => 'localhost', 'db_port' => '3306', 'db_name' => 'thinkphp' );
如果我們已經在設定檔中配置了額外的資料庫連接資訊,例如:
//資料庫配置1 'DB_CONFIG1' = array( 'db_type' => 'mysql', 'db_user' => 'root', 'db_pwd' => '1234', 'db_host' => 'localhost', 'db_port' => '3306', 'db_name' => 'thinkphp' ), //資料庫配置2 'DB_CONFIG2' => 'mysql://root:1234@localhost:3306/thinkphp';
那麼,我們可以把模型類的屬性定義改為:
//調用設定檔中的資料庫配置1 protected $connection = 'DB_CONFIG1';
或者:
//調用設定檔中的資料庫配置2 protected $connection = 'DB_CONFIG2';
這種方式的優點可以支援不同資料庫類型,也就是說可以和當前的項目設定檔中的資料庫類型不同,缺點是必須使用D方法執行個體化,而且不能動態設定。
3.模型執行個體化指定串連
新版支援在執行個體化模型的時候指定資料庫連接,例如:
$User = new Model('User','think_','mysql://root:1234@localhost/thinkphp');
或者使用M方法執行個體化:
$User = M('User','think_','mysql://root:1234@localhost/thinkphp');
M方法的第二個參數是資料表的首碼,如果留空表示採用項目配置的資料表首碼,第三個參數則是當前執行個體化需要的資料庫連接資訊。
同樣的道理,在執行個體化中傳入的資料庫連接資訊也可以採用配置名稱的方式,例如:
$User = M('User','think_','DB_CONFIG2');
如果當前操作不需要切換資料庫連接,只是需要切換資料庫,則可以採用:
$User = M('top.User','think_');
表示執行個體化top資料庫的think_user資料表。如果你的資料表沒有首碼,可以使用
$User = M('top.User',null);
表示執行個體化top資料庫的user表。
4.動態切換串連
系統還提供了更靈活的動態操作,可以使用模型類提供的db方法進行多資料庫連接和切換操作,用法:
Model->db("資料庫編號","資料庫配置");
資料庫編號用數字格式,對於已經調用過的資料庫連接,是不需要再傳入資料庫連接資訊的,系統會自動記錄。對於初始化的資料庫連接,內部的資料庫編號是0,因此為了避免衝突,請不要再次定義資料庫編號為0的資料庫配置。
資料庫配置的定義方式和模型定義connection屬性一樣,支援數組、字串以及調用配置參數三種格式。
Db方法調用後返回當前的模型執行個體,直接可以繼續進行模型的其他動作,所以該方法可以在查詢的過程中動態切換,例如:
$this->db(1,"mysql://root:123456@localhost:3306/test")->query("查詢SQL");
該方法添加了一個編號為1的資料庫連接,並自動切換到當前的資料庫連接。
當第二次切換到相同的資料庫的時候,就不需要傳入資料庫連接資訊了,可以直接使用:
$this->db(1)->query("查詢SQL");
在沒有再次進行資料庫切換之前,當前的所有操作都是針對db(1)所設定的資料庫。
如果需要切換到預設的資料庫連接,只需要調用:
$this->db(0);
如果我們已經在項目配置中定義了其他的資料庫連接資訊,我們就可以直接在db方法中調用配置進行串連了:
$this->db(1,"DB_CONFIG1")->query("查詢SQL");$this->db(2,"DB_CONFIG2")->query("查詢SQL");
如果切換資料庫之後,資料表和當前不一致的話,可以使用table方法指定要操作的資料表:
$this->db(1)->table("top_user")->find();
如果要返回當前的資料庫連接,可以直接調用空的db方法即可,例如:
$db = $this->db();
http://www.bkjia.com/PHPjc/825453.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/825453.htmlTechArticle通常情況下,如果一個應用只是操作同一個資料庫(或者分散式資料庫)的話,你只需要在項目設定檔中定義資料庫連接資訊即可。這裡...