天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ThinkPHP3.1新特性之多數據庫操作更加完善

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

對于早期版本的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();

php技術ThinkPHP3.1新特性之多數據庫操作更加完善,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 无遮掩H黄纯肉动漫在线观看星 | 久久毛片视频 | 精品国产乱码久久久久久下载 | 自拍视频亚洲综合在线精品 | aaaaaaa一级毛片 | 国产精品无码亚洲网 | 亚洲人成7777| 91精品欧美一区二区三区 | 3D内射动漫同人资源在线观看 | 侮辱丰满美丽的人妻 | 国产产乱码一二三区别免费 | 中文字幕亚洲无线码在线 | 亚洲大码熟女在线 | 99精品观看| 国产精品久久人妻互换毛片 | 性欧美videofree中文字幕 | 精品国产自在现线拍国语 | 精选国产AV精选一区二区三区 | 日韩中文字幕欧美在线视频 | 国产色婷婷精品人妻蜜桃成熟时 | 美女脱内衣裸身尿口露出来 | 日本高清不卡码无码v亚洲 日本福利片午夜免费观着 日本粉嫩学生毛绒绒 | 国产三级在线精品男人的天堂 | 国产欧美日韩综合精品一区二区 | 黑人巨大两根一起挤进欧美 | 麻豆AV久久AV盛宴AV | 久久re这里视频只精品首页 | 欧美香蕉大胸在线视频观看 | 好男人社区 | 久久re这里精品在线视频7 | 中文字幕精品在线观看 | 九色PORNY丨视频入口 | a级毛片黄免费a级毛片 | 国产成人免费片在线视频观看 | 亚洲日韩在线观看 | 日本妈妈在线观看中文字幕 | 国产成人精品久久久久婷婷 | 极品内射少妇精品无码视频 | 国产在线播放精品视频 | 国产精品女上位好爽在线短片 | 内射白浆一区二区在线观看 |