花魁直播高品质美女在线视频互动社区 - 花魁直播官方版

 歡迎來到素材無憂網(wǎng),按 + 收藏我們
登錄 注冊 退出 找回密碼

ThinkPHP中連接mysql數(shù)據(jù)庫的四種實用和通用的連接方法

時間: 2020-09-15 15:33 閱讀: 作者:素材無憂網(wǎng)

ThinkPHP內(nèi)置了抽象數(shù)據(jù)庫訪問層,把不同的數(shù)據(jù)庫操作封裝起來,我們只需要使用公共的Db類進行操作,而無需針對不同的數(shù)據(jù)庫寫不同的代碼和底層實現(xiàn),Db類會自動調(diào)用相應(yīng)的數(shù)據(jù)庫適配器來處理。目前的數(shù)據(jù)庫包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果應(yīng)用需要使用數(shù)據(jù)庫,必須配置數(shù)據(jù)庫連接信息,數(shù)據(jù)庫的配置文件有多種定義方式:

/alidata/www/xxx/Apps/Common/Conf/config.php   

/alidata/www/xxx/Apps/User/Conf/config.php

第一種 在項目配置文件里面定義

在項目的配置文件Config/config.php 文件里,增加以下數(shù)據(jù)庫配置選項即可達到數(shù)據(jù)庫連接目的:

PHP Code復制內(nèi)容到剪貼板


return array(  
‘DB_TYPE’=> ‘mysql’,  
‘DB_HOST’=> ‘localhost’,  
‘DB_NAME’=>’thinkphp’,  
‘DB_USER’=>’root’,  
‘DB_PWD’=>”,  
‘DB_PORT’=>’3306′,  
‘DB_PREFIX’=>’think_’,  
// 其他項目配置參數(shù)………  
);  

系統(tǒng)推薦使用該種方式,因為一般一個項目的數(shù)據(jù)庫訪問配置是相同的。該方法系統(tǒng)在連接數(shù)據(jù)庫的時候會自動獲取,無需手動連接。

可以對每個項目定義不同的數(shù)據(jù)庫連接信息,還可以在調(diào)試配置文件(Conf/debug.php)里面定義調(diào)試數(shù)據(jù)庫的配置信息,如果在項目配置文件和調(diào)試模式配置文件里面同時定義了數(shù)據(jù)庫連接信息,那么在調(diào)試模式下面后者生效,部署模式下面前者生效。

第二種 使用DSN方式在初始化Db類的時候傳參數(shù)

使用這種時,提醒大家,可以把后面的dns做為配置文件,這樣方便統(tǒng)一修改;

$db_dsn = “mysql://username:passwd@localhost:3306/DbName”;  
$db = new Db($db_dsn);  

該方式主要用于在控制器里面自己手動連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個數(shù)據(jù)庫連接。

第三種 使用數(shù)組傳參數(shù)

$DSN = array(  
‘dbms’ => ‘mysql’,  
‘username’ => ‘username’,  
‘password’ => ‘password’,  
‘hostname’ => ‘localhost’,  
‘hostport’ => ’3306′,  
‘database’ => ‘dbname’  
);  
$db = new Db($DSN);  

該方式也是用于手動連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個數(shù)據(jù)庫連接。

第四種 在模型類里面定義

如果是單獨只有某個模型下獨立去連接某些數(shù)據(jù)庫服務(wù)器時,可以使用這個單獨設(shè)置的方法:

protected $connection = array(  
‘dbms’ => ‘mysql’,  
‘username’ => ‘username’,  
‘password’ => ‘password’,  
‘hostname’ => ‘localhost’,  
‘hostport’ => ’3306′,  
‘database’ => ‘dbname’  
);  

果在某個模型類里面定義了connection屬性,則在實例化模型對象的時候,會使用該數(shù)據(jù)庫連接信息進行數(shù)據(jù)庫連接。通常用于某些數(shù)據(jù)表位于當前數(shù)據(jù)庫連接之外的其它數(shù)據(jù)庫。

ThinkPHP并不是在一開始就會連接數(shù)據(jù)庫,而是在有數(shù)據(jù)查詢操作的時候才會去連接數(shù)據(jù)庫。額外的情況是,在系統(tǒng)第一次操作模型的時候,框架會自動連接數(shù)據(jù)庫獲取相關(guān)模型類的數(shù)據(jù)字段信息,并緩存下來。

(字段緩存目錄:Runtime/Data/_fields)

ThinkPHP支持PDO方式,如果要使用PDO方式連接數(shù)據(jù)庫,可以參考下面的設(shè)置。

我們以項目配置文件定義為例來說明:

 

 

版權(quán)聲明: 本站資源均來自互聯(lián)網(wǎng)或會員發(fā)布,如果侵犯了您的權(quán)益請與我們聯(lián)系,我們將在24小時內(nèi)刪除!謝謝!

轉(zhuǎn)載請注明: ThinkPHP中連接mysql數(shù)據(jù)庫的四種實用和通用的連接方法

相關(guān)文章
模板推薦