您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關在ThinkPHP中連接數據庫的方法有哪些,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
php是一個嵌套的縮寫名稱,是英文超級文本預處理語言,它的語法混合了C、Java、Perl以及php自創新的語法,主要用來做網站開發,許多小型網站都用php開發,因為php是開源的,從而使得php經久不衰。
第一種:在項目配置文件里面定義
復制代碼 代碼如下:
return array(
'DB_TYPE'=> 'mysql',
'DB_HOST'=> 'localhost',
'DB_NAME'=>'thinkphp',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PORT'=>'3306',
'DB_PREFIX'=>'think_',
// 其他項目配置參數………
);
系統推薦使用該種方式,因為一般一個項目的數據庫訪問配置是相同的,該方法系統在連接數據庫的時候會自動獲取,無需手動連接.
可以對每個項目定義不同的數據庫連接信息,還可以在調試配置文件(Conf/debug.php)里面定義調試數據庫的配置信息,如果在項目配置文件和調試模式配置文件里面同時定義了數據庫連接信息,那么在調試模式下面后者生效,部署模式下面前者生效.
第二種 使用DSN方式在初始化Db類的時候傳參數
復制代碼 代碼如下:
$db_dsn = "mysql://username:passwd@localhost:3306/DbName";
$db = new Db($db_dsn);
該方式主要用于在控制器里面自己手動連接數據庫的情況,或者用于創建多個數據庫連接.
第三種 使用數組傳參數
復制代碼 代碼如下:
$DSN = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
$db = new Db($DSN);
該方式也是用于手動連接數據庫的情況,或者用于創建多個數據庫連接.
第四種 在模型類里面定義
復制代碼 代碼如下:
protected $connection = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
// 或者使用下面的定義
protected $connection = "mysql://username:passwd@localhost:3306/DbName";
如果在某個模型類里面定義了connection屬性,則在實例化模型對象的時候,會使用該數據庫連接信息進行數據庫連接,通常用于某些數據表位于當前數據庫連接之外的其它數據庫.
ThinkPHP并不是在一開始就會連接數據庫,而是在有數據查詢操作的時候才會去連接數據庫,額外的情況是,在系統第一次操作模型的時候,框架會自動連接數據庫獲取相關模型類的數據字段信息,并緩存下來.
(字段緩存目錄:Runtime/Data/_fields)
ThinkPHP支持PDO方式,如果要使用PDO方式連接數據庫,可以參考下面的設置.
我們以項目配置文件定義為例來說明:
復制代碼 代碼如下:
return array(
'DB_TYPE'=> 'pdo',
// 注意DSN的配置針對不同的數據庫有所區別 請參考PHP手冊PDO類庫部分
'DB_DSN'=> 'mysql:host=localhost;dbname=think',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PREFIX'=>'think_',
// 其他項目配置參數………
);
使用PDO方式的時候,要注意檢查是否開啟相關的PDO模塊,DB_DSN參數僅對PDO方式連接才有效.
上述就是小編為大家分享的在ThinkPHP中連接數據庫的方法有哪些了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。