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

首頁 > 開發(fā) > ThinkPHP > 正文

ThinkPHP連接數(shù)據(jù)庫的幾種方式

2024-09-09 15:19:51
字體:
來源:轉載
供稿:網(wǎng)友

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

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

  1. return array
  2. 'DB_TYPE'=> 'mysql',  
  3. 'DB_HOST'=> 'localhost'
  4. 'DB_NAME'=>'thinkphp',  
  5. 'DB_USER'=>'root',  
  6. 'DB_PWD'=>'',  
  7. 'DB_PORT'=>'3306'
  8. 'DB_PREFIX'=>'think_'
  9. // 其他項目配置參數(shù)……… 
  10. ); 

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

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

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

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

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

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

  1. $DSN = array(  
  2. 'dbms'     => 'mysql',   
  3. 'username' => 'username',   
  4. 'password' => 'password',   
  5. 'hostname' => 'localhost',   
  6. 'hostport' => '3306',   
  7. 'database' => 'dbname'  
  8. ); 
  9.  $db = new Db($DSN); 

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

第四種 在模型類里面定義

  1. protected $connection = array(  
  2. 'dbms'     => 'mysql',   
  3. 'username' => 'username',   
  4. 'password' => 'password',   
  5. 'hostname' => 'localhost',   
  6. 'hostport' => '3306',   
  7. 'database' => 'dbname'  
  8. ); 
  9. // 或者使用下面的定義 
  10. protected $connection = ”mysql://username:passwd@localhost:3306/DbName”; 

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

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

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

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

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

  1. return array
  2. 'DB_TYPE'=> 'pdo',  
  3. // 注意DSN的配置針對不同的數(shù)據(jù)庫有所區(qū)別 請參考PHP手冊PDO類庫部分 
  4. 'DB_DSN'=> 'mysql:host=localhost;dbname=think'
  5. 'DB_USER'=>'root',  
  6. 'DB_PWD'=>'',  
  7. 'DB_PREFIX'=>'think_'
  8. // 其他項目配置參數(shù)……… 
  9. ); 

使用PDO方式的時候,要注意檢查是否開啟相關的PDO模塊,DB_DSN參數(shù)僅對PDO方式連接才有效.

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 株洲县| 固镇县| 湖北省| 句容市| 都安| 定州市| 普洱| 乌拉特前旗| 怀远县| 绥滨县| 楚雄市| 五莲县| 河津市| 鸡泽县| 比如县| 池州市| 曲周县| 拜城县| 丰顺县| 淳安县| 曲水县| 忻州市| 三明市| 淮滨县| 丹阳市| 天台县| 德州市| 江阴市| 富裕县| 庆安县| 博客| 永修县| 黄浦区| 平泉县| 临澧县| 郎溪县| 泸州市| 元朗区| 青冈县| 柘荣县| 新密市|