多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php框架 > ThinkPHP > ThinkPHP3.1新特性:多數據操作的完善

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

來源:程序員人生   發布時間:2013-12-26 07:42:10 閱讀次數:3725次
正常情況下,如果應用只是操作同一個數據庫(或者分布式數據庫)的話,你只需要在項目配置文件中定義數據庫連接信息即可。這里說的多數據庫操作一般指的是在一個應用中會操作不同的數據庫(包括同類型的和不同類型的數據庫),甚至包括動態切換多數據庫的情況。
早期版本的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
    '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方法實例化,而且不能動態設定。

模型實例化指定連接

新版支持在實例化模型的時候指定數據庫連接,例如:
$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();
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: videosfree性欧美另类 | 欧美一级毛片香蕉网 | 精品国产午夜肉伦伦影院 | 波多野结衣中文字幕一区二区三区 | 一级做a爰片性色毛片小说 一级做a爰片性色毛片新版的 | 久久一本精品久久精品66 | 在线a亚洲视频播放在线观看 | 三级全黄在线观看www桃花 | 亚洲国产激情一区二区三区 | 91精品福利观看 | 欧美极品尤物在线播放一级 | 日韩中文精品亚洲第三区 | 黄色小说校园春色 | 久久久久久毛片免费观看 | 亚洲综合欧美日本另类激情 | 亚洲欧美在线免费观看 | 娇小老少配xxxxx性视频 | 最新国产一区二区精品久久 | 欧美理伦视频 | 中文字幕一区二区三区亚洲精品 | 日本aaaaa特黄毛片 | 日韩大片免费观看 | 日本特一级毛片免费视频 | 日本在线一本 | 国产成人精品一区二三区 | 亚洲成综合人影院在院播放 | 2021国产精品系列一区二区 | 性做久久久久久蜜桃花 | www视频免费在线观看 | 亚洲国产片高清在线观看 | 欧美一级久久久久久久大片动画 | 最新亚洲国产有精品 | 99精品国产美女福到在线不卡 | 久久不色| v视界成人影院在线视频 | 91精品综合国产在线观看 | 老司机福利在线观看 | 亚洲精品国产一区二区三 | freexxxhd性欧美 | 色综合久久久高清综合久久久 | 国产成人a一区二区 |