ThinkPHP內置了抽象數據庫訪問層,把不同的數據庫操作封裝起來,我們只需要使用公共的Db類進行操作,而無需針對不同的數據庫寫不同的代碼和底層實現,Db類會自動調用相應的數據庫適配器來處理。目前的數據庫包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果應用需要使用數據庫,必須配置數據庫連接信息,數據庫的配置文件有多種定義方式:
第一種 在項目配置文件里面定義
在項目的配置文件Config/config.php 文件里,增加以下數據庫配置選項即可達到數據庫連接目的:
PHP Code
復制內容到剪貼板
- 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類的時候傳參數
使用這種時,
it動力提醒大家,可以把后面的dns做為配置文件,這樣方便統一修改;
PHP Code
復制內容到剪貼板
- $db_dsn = “mysql://username:passwd@localhost:3306/DbName”;
- $db = new Db($db_dsn);
該方式主要用於在控制器里面自己手動連接數據庫的情況,或者用於創建多個數據庫連接。
第三種 使用數組傳參數
PHP Code
復制內容到剪貼板
- $DSN = array(
- ‘dbms’ => ‘mysql’,
- ‘username’ => ‘username’,
- ‘password’ => ‘password’,
- ‘hostname’ => ‘localhost’,
- ‘hostport’ => ’3306′,
- ‘database’ => ‘dbname’
- );
- $db = new Db($DSN);
該方式也是用於手動連接數據庫的情況,或者用於創建多個數據庫連接。
第四種 在模型類里面定義
如果是單獨只有某個模型下獨立去連接某些數據庫服務器時,可以使用這個單獨設置的方法:
PHP Code
復制內容到剪貼板
- protected $connection = array(
- ‘dbms’ => ‘mysql’,
- ‘username’ => ‘username’,
- ‘password’ => ‘password’,
- ‘hostname’ => ‘localhost’,
- ‘hostport’ => ’3306′,
- ‘database’ => ‘dbname’
- );
// 或者使用下面的定義
PHP Code
復制內容到剪貼板
- protected $connection = ”mysql://username:passwd@localhost:3306/DbName”;
如果在某個模型類里面定義了connection屬性,則在實例化模型對象的時候,會使用該數據庫連接信息進行數據庫連接。通常用於某些數據表位於當前數據庫連接之外的其它數據庫。
ThinkPHP並不是在一開始就會連接數據庫,而是在有數據查詢操作的時候才會去連接數據庫。額外的情況是,在系統第一次操作模型的時候,框架會自動連接數據庫獲取相關模型類的數據字段信息,並緩存下來。
(字段緩存目錄:Runtime/Data/_fields)
ThinkPHP支持PDO方式,如果要使用PDO方式連接數據庫,可以參考下面的設置。
我們以項目配置文件定義為例來說明:
PHP Code
復制內容到剪貼板
- 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下也是比較全面的了。大家可以多多嘗試不同連接,可以在項目適合的地方使用恰當的數據庫連接方式。
好了,我們介紹的一些連接數據庫方法在Thinkphp下也是比較全面的了。大家可以多多嘗試不同連接,可以在項目適合的地方使用恰當的數據庫連接方式。
ThinkPHP的數據庫相關推薦文章:
1、ThinkPHP框架中快捷函數創建模型 M和D的區別
2、THINKPHP數據CURD基本操作方法
3、thinkphp學習筆記入門小知識點分享