麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > ThinkPHP > 正文

ThinkPHP3.1新特性 多數(shù)據(jù)庫操作的完善

2024-09-09 15:19:48
字體:
供稿:網(wǎng)友

ThinkPHP3.1新特性 多數(shù)據(jù)庫操作的完善

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

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

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

模型定義數(shù)據(jù)庫

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

protected $dbName = 'top';

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

$User = D('User');

這種方式定義的前提是當(dāng)前數(shù)據(jù)庫用戶賬戶有操作top數(shù)據(jù)庫的權(quán)限。

模型定義數(shù)據(jù)庫連接

如果你的跨庫操作需要使用不同的數(shù)據(jù)庫連接賬號或者需要連接不同類型的數(shù)據(jù)庫,可以直接在模型類里面定義connection屬性,在操作該模型類的時(shí)候,就會自動連接到指定的數(shù)據(jù)庫,例如:

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ù)庫連接信息,例如:

  1. //數(shù)據(jù)庫配置1     'DB_CONFIG1' = array(         'db_type'  => 'mysql',         'db_user'  => 'root',         'db_pwd'   => '1234',         'db_host'  => 'localhost',         'db_port'  => '3306',         'db_name'  => 'thinkphp'     ),     //數(shù)據(jù)庫配置2     'DB_CONFIG2' => 'mysql://root:1234@localhost:3306/thinkphp'; 
  2. 那么,我們可以把模型類的屬性定義改為: 
  3. //調(diào)用配置文件中的數(shù)據(jù)庫配置1 protected $connection = 'DB_CONFIG1'; 
  4. //或者: 
  5. //調(diào)用配置文件中的數(shù)據(jù)庫配置2 protected $connection = 'DB_CONFIG2'; 

這種方式的優(yōu)點(diǎn)可以支持不同數(shù)據(jù)庫類型,也就是說可以和當(dāng)前的項(xiàng)目配置文件中的數(shù)據(jù)庫類型不同,缺點(diǎn)是必須使用D方法實(shí)例化,而且不能動態(tài)設(shè)定。

模型實(shí)例化指定連接

新版支持在實(shí)例化模型的時(shí)候指定數(shù)據(jù)庫連接,例如:

$User = new Model('User','think_','mysql://root:1234@localhost/thinkphp'); 

或者使用M方法實(shí)例化:

$User = M('User','think_','mysql://root:1234@localhost/thinkphp'); 

M方法的第二個參數(shù)是數(shù)據(jù)表的前綴,如果留空表示采用項(xiàng)目配置的數(shù)據(jù)表前綴,第三個參數(shù)則是當(dāng)前實(shí)例化需要的數(shù)據(jù)庫連接信息。

同樣的道理,在實(shí)例化中傳入的數(shù)據(jù)庫連接信息也可以采用配置名稱的方式,例如:

$User = M('User','think_','DB_CONFIG2'); 

如果當(dāng)前操作不需要切換數(shù)據(jù)庫連接,只是需要切換數(shù)據(jù)庫,則可以采用:

$User = M('top.User','think_'); 

表示實(shí)例化top數(shù)據(jù)庫的think_user數(shù)據(jù)表,如果你的數(shù)據(jù)表沒有前綴,可以使用

$User = M('top.User',null); 

表示實(shí)例化top數(shù)據(jù)庫的user表。

動態(tài)切換連接

系統(tǒng)還提供了更靈活的動態(tài)操作,可以使用模型類提供的db方法進(jìn)行多數(shù)據(jù)庫連接和切換操作,用法:

Model->db("數(shù)據(jù)庫編號","數(shù)據(jù)庫配置");

數(shù)據(jù)庫編號用數(shù)字格式,對于已經(jīng)調(diào)用過的數(shù)據(jù)庫連接,是不需要再傳入數(shù)據(jù)庫連接信息的,系統(tǒng)會自動記錄,對于初始化的數(shù)據(jù)庫連接,內(nèi)部的數(shù)據(jù)庫編號是0,因此為了避免沖突,請不要再次定義數(shù)據(jù)庫編號為0的數(shù)據(jù)庫配置。

數(shù)據(jù)庫配置的定義方式和模型定義connection屬性一樣,支持?jǐn)?shù)組、字符串以及調(diào)用配置參數(shù)三種格式。

Db方法調(diào)用后返回當(dāng)前的模型實(shí)例,直接可以繼續(xù)進(jìn)行模型的其他操作,所以該方法可以在查詢的過程中動態(tài)切換,例如:

$this->db(1,"mysql://root:123456@localhost:3306/test")->query("查詢SQL");

該方法添加了一個編號為1的數(shù)據(jù)庫連接,并自動切換到當(dāng)前的數(shù)據(jù)庫連接。

當(dāng)?shù)诙吻袚Q到相同的數(shù)據(jù)庫的時(shí)候,就不需要傳入數(shù)據(jù)庫連接信息了,可以直接使用:

$this->db(1)->query("查詢SQL");

在沒有再次進(jìn)行數(shù)據(jù)庫切換之前,當(dāng)前的所有操作都是針對db(1)所設(shè)置的數(shù)據(jù)庫。

如果需要切換到默認(rèn)的數(shù)據(jù)庫連接,只需要調(diào)用:

$this->db(0);

如果我們已經(jīng)在項(xiàng)目配置中定義了其他的數(shù)據(jù)庫連接信息,我們就可以直接在db方法中調(diào)用配置進(jìn)行連接了:

$this->db(1,"DB_CONFIG1")->query("查詢SQL"); $this->db(2,"DB_CONFIG2")->query("查詢SQL");

如果切換數(shù)據(jù)庫之后,數(shù)據(jù)表和當(dāng)前不一致的話,可以使用table方法指定要操作的數(shù)據(jù)表:

$this->db(1)->table("top_user")->find();

如果要返回當(dāng)前的數(shù)據(jù)庫連接,可以直接調(diào)用空的db方法即可,例如:

$db = $this->db();

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 中文字幕偷拍 | 精品国产高清一区二区三区 | 九九视屏 | 99视频在线观看视频 | 国产精品久久久久久影视 | 成人免费看视频 | 国产美女做爰免费视 | 黄色毛片免费视频 | 可以免费看的av | 国产毛片在线高清视频 | 精品久久久久久久久久久aⅴ | 天天操天天骑 | 日本欧美国产 | 久久久成人精品视频 | 亚洲精品91| 国产毛片aaa一区二区三区视频 | 国产成人强伦免费视频网站 | 操碰网| 午夜男人在线观看 | 久色porn | 99亚洲伊人久久精品影院红桃 | 国色天香综合网 | 国产精品入口夜色视频大尺度 | 91av大片| 水卜樱一区二区av | 香蕉秀| 粉嫩一区| 久久精品re | 超碰人人做人人爱 | av电影院在线观看 | 日韩视频1 | 久久精品视频首页 | 蜜桃成品人免费视频 | 国产精品美女久久久免费 | 未成年人在线观看 | 成人视屏在线观看 | 免费毛片在线视频 | 国产男女 爽爽爽爽视频 | 少妇一级淫片高潮流水电影 | 免费一区二区三区 | 国产亚洲欧美日韩在线观看不卡 |