搜尋
首頁php框架ThinkPHPthinkphp怎麼連接資料庫

thinkphp怎麼連接資料庫

Aug 26, 2019 pm 02:20 PM
thinkphp資料庫連接

thinkphp怎麼連接資料庫

本文實例匯總了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)裡面定義調試數據庫的配置信息,如果在項目配置文件和調試模式配置文件裡面同時定義了資料庫連接訊息,那麼在調試模式下面後者生效,部署模式下面前者生效。

相關推薦:《ThinkPHP教學

#第二種、使用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中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),