亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > ThinkPHP > 正文

ThinkPHP3.1新特性 多數據庫操作的完善

2024-09-09 15:19:48
字體:
來源:轉載
供稿:網友

ThinkPHP3.1新特性 多數據庫操作的完善

正常情況下,如果應用只是操作同一個數據庫(或者分布式數據庫)的話,你只需要在項目配置文件中定義數據庫連接信息即可,這里說的多數據庫操作一般指的是在一個應用中會操作不同的數據庫(包括同類型的和不同類型的數據庫),甚至包括動態切換多數據庫的情況。

早期版本的ThinkPHP切換數據庫需要使用高級模型,現在可以更加輕松的解決了。

新版對多數據的支持有下面幾種方式,開發人員可以根據實際情況選擇合適的方式操作:

模型定義數據庫

如果只是簡單的跨庫操作,并且只是個別模型類的話,你可以直接在模型類中定義dbName屬性即可:

protected $dbName = 'top';

實例化的時候,記得要使用D方法,例如:

$User = D('User');

這種方式定義的前提是當前數據庫用戶賬戶有操作top數據庫的權限。

模型定義數據庫連接

如果你的跨庫操作需要使用不同的數據庫連接賬號或者需要連接不同類型的數據庫,可以直接在模型類里面定義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. //數據庫配置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'; 
  2. 那么,我們可以把模型類的屬性定義改為: 
  3. //調用配置文件中的數據庫配置1 protected $connection = 'DB_CONFIG1'; 
  4. //或者: 
  5. //調用配置文件中的數據庫配置2 protected $connection = 'DB_CONFIG2'; 

這種方式的優點可以支持不同數據庫類型,也就是說可以和當前的項目配置文件中的數據庫類型不同,缺點是必須使用D方法實例化,而且不能動態設定。

模型實例化指定連接

新版支持在實例化模型的時候指定數據庫連接,例如:

$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表。

動態切換連接

系統還提供了更靈活的動態操作,可以使用模型類提供的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();

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91情侣偷在线精品国产| 久青草国产97香蕉在线视频| 欧美大片欧美激情性色a∨久久| 亚洲伊人成综合成人网| 欧美久久精品午夜青青大伊人| 555www成人网| 最近中文字幕2019免费| 国产日韩在线亚洲字幕中文| 欧美一级大片在线观看| 欧美视频在线观看 亚洲欧| 国产成人一区二区| 亚洲高清福利视频| www.亚洲一二| 欧美黑人巨大精品一区二区| 在线国产精品视频| 国产日产欧美a一级在线| 日韩在线观看免费网站| 欧美成人激情视频免费观看| 欧美性20hd另类| 91精品国产色综合久久不卡98| 久久男人的天堂| 久久久精品在线| 欧美又大粗又爽又黄大片视频| 欧美性jizz18性欧美| 91亚洲精品久久久久久久久久久久| 91网站免费看| 国产精品爱久久久久久久| 国产精品久久久久一区二区| 日韩欧美在线国产| 欧美日韩中文字幕在线视频| 亚洲xxxx18| 国自产精品手机在线观看视频| 神马久久桃色视频| 欧美第一黄网免费网站| 亚洲精品91美女久久久久久久| 成人福利在线视频| 欧美精品久久久久| 欧洲一区二区视频| 92福利视频午夜1000合集在线观看| 亚洲视频综合网| 欧美一区在线直播| 欧美性高潮床叫视频| 91黑丝在线观看| 人九九综合九九宗合| 国产中文字幕91| 国产91精品久久久久久久| 久久精品国产成人精品| 亚洲国产欧美一区| 成人高清视频观看www| 8x海外华人永久免费日韩内陆视频| 中文字幕日韩欧美在线视频| 美女av一区二区| 97色伦亚洲国产| 欧美日韩中文在线观看| 国产97在线播放| 亚洲天堂日韩电影| 欧美猛交免费看| 欧美乱大交做爰xxxⅹ性3| 92福利视频午夜1000合集在线观看| 国产主播喷水一区二区| 欧美日韩美女在线| 92国产精品久久久久首页| 日韩电影免费观看在线观看| 亚洲色图欧美制服丝袜另类第一页| 久久精品电影一区二区| 久久91亚洲精品中文字幕奶水| 国产成人精品日本亚洲专区61| 日韩在线激情视频| 久久久这里只有精品视频| 亚洲国产中文字幕久久网| 国产欧美最新羞羞视频在线观看| 欧美日本亚洲视频| 国产欧美日韩免费| 国产网站欧美日韩免费精品在线观看| 国产成人黄色av| 亚洲尤物视频网| 欧美高清第一页| 亚洲综合中文字幕68页| 亚洲精品成人久久久| 国产香蕉一区二区三区在线视频| 中文字幕亚洲一区在线观看| 色综合天天综合网国产成人网| 国产精品成人久久久久| 久久综合久久88| 久久6免费高清热精品| 欧美视频在线观看免费| 91精品一区二区| 亚洲精品中文字幕av| 成人激情视频网| 这里只有精品在线播放| 国产精品手机播放| 国产精品成人观看视频国产奇米| 日本国产精品视频| 欧美xxxx14xxxxx性爽| 国产亚洲精品久久久久久| 亚洲男人第一网站| 欧美日韩精品在线观看| 久久精品国产欧美激情| 亚洲a在线播放| 欧美日韩在线一区| 亚洲美女在线视频| 亚洲国产精品久久久久久| 亚洲一区二区黄| 日韩av网址在线| 国产精品久久久久999| 国产亚洲日本欧美韩国| 中文字幕亚洲综合| 伦理中文字幕亚洲| 欧美精品成人91久久久久久久| 久久国产精品首页| 欧美激情欧美激情在线五月| 亚洲在线www| 91成人在线视频| wwwwwwww亚洲| 久久人人爽人人爽人人片av高清| 1769国产精品| 成人精品视频久久久久| 日本成人在线视频网址| 亚洲伊人第一页| 日韩精品欧美激情| 国产精品普通话| 日韩亚洲欧美中文在线| 国产精品午夜视频| 亚洲自拍中文字幕| 欧美日韩国产综合新一区| 国产视频精品va久久久久久| 亚洲精品久久久久中文字幕欢迎你| 日韩欧美在线视频免费观看| 国产精品美女久久久久av超清| 欧洲精品在线视频| 欧美特级www| 精品久久久免费| 欧美日韩在线视频一区二区| 成人国产精品av| 亚洲国产日韩欧美在线动漫| 成人精品福利视频| 97成人精品区在线播放| 夜夜躁日日躁狠狠久久88av| 精品综合久久久久久97| 狠狠躁18三区二区一区| 成人免费大片黄在线播放| 欧美成人在线影院| 日本久久精品视频| 欧美黑人一区二区三区| 成人福利视频网| 欧美性受xxx| 成人精品在线视频| 欧美成年人视频网站欧美| 日韩av综合中文字幕| 国产成人一区二区三区电影| 久久久成人的性感天堂| 亚洲天堂男人天堂| 欧美在线视频导航| 欧美成人免费全部观看天天性色| 国产精品免费一区二区三区都可以| 亚洲欧美国产精品| 国产精品亚洲一区二区三区| 日韩免费高清在线观看| 欧美高清视频在线观看| 欧美另类高清videos| 一区二区三区 在线观看视| 亚洲欧美日韩中文在线制服| 国产精品丝袜久久久久久高清| 国内伊人久久久久久网站视频|