国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

ThinkPHP連接數據庫的方式匯總

2024-05-04 23:28:40
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了ThinkPHP連接數據庫的方式,包括項目配置文件定義、DSN方式傳參、數組傳參、模型類里定義等,非常具有實用價值,需要的朋友可以參考下
 
 

本文實例匯總了ThinkPHP連接數據庫的幾種常用方式。分享給大家供大家參考。具體如下:

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

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

復制代碼代碼如下:
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框架的PHP程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 扶绥县| 商河县| 台南县| 九江县| 黄平县| 大新县| 武陟县| 广饶县| 青浦区| 鹿邑县| 靖远县| 新乡市| 彭泽县| 辽源市| 清水河县| 岐山县| 池州市| 天等县| 花莲市| 吴忠市| 云安县| 溆浦县| 上饶市| 梁山县| 乌审旗| 保山市| 大埔县| 白沙| 景德镇市| 精河县| 溧阳市| 湘阴县| 河池市| 商南县| 清徐县| 宜兰市| 湛江市| 鹤庆县| 吉木萨尔县| 平和县| 永宁县|