好記憶力不如爛筆頭6.8 切換數(shù)據(jù)庫如果你需要切換到另外一個(gè)數(shù)據(jù)庫(包括在相同和不同的數(shù)據(jù)庫類型之間切換)或者需要連接多個(gè)數(shù)據(jù)庫進(jìn)行操作不同的數(shù)據(jù),就需要使用ThinkPHP提供的數(shù)據(jù)庫切換方法,用法很簡(jiǎn)單, 只需要調(diào)用Model類的db方法,用法: 數(shù)據(jù)庫編號(hào)用數(shù)字格式,對(duì)于已經(jīng)調(diào)用過的數(shù)據(jù)庫連接,是不需要再傳入數(shù)據(jù)庫連接信息的,系統(tǒng)會(huì)自動(dòng)記錄。對(duì)于默認(rèn)的數(shù)據(jù)庫連接,內(nèi)部的數(shù)據(jù)庫編號(hào)是0,因此為了避免沖突,請(qǐng)不要再次定義數(shù)據(jù)庫編號(hào)為0的數(shù)據(jù)庫配置。數(shù)據(jù)庫配置的定義方式和模型定義connection屬性一樣,支持?jǐn)?shù)組、字符串以及調(diào)用配置參數(shù)三種格式。 Db方法調(diào)用后返回當(dāng)前的模型實(shí)例,直接可以繼續(xù)進(jìn)行模型的其他操作,所以該方法可以在查詢的過程中動(dòng)態(tài)切換,例如: 該方法添加了一個(gè)編號(hào)為1的數(shù)據(jù)庫連接,并自動(dòng)切換到當(dāng)前的數(shù)據(jù)庫連接。當(dāng)?shù)诙吻袚Q到相同的數(shù)據(jù)庫的時(shí)候,就不需要傳入數(shù)據(jù)庫連接信息了,可以直接使用: 如果需要切換到默認(rèn)的數(shù)據(jù)庫連接,只需要調(diào)用:
1 如果我們已經(jīng)在項(xiàng)目配置中定義了其他的數(shù)據(jù)庫連接信息,例如:
我們就可以直接在db方法中調(diào)用配置進(jìn)行連接了: 如果切換數(shù)據(jù)庫之后,數(shù)據(jù)表和當(dāng)前不一致的話,可以使用table方法指定要操作的數(shù)據(jù)表: 我們也可以直接用M方法切換數(shù)據(jù)庫,例如: 或者
|
|