ThinkPHP連接數(shù)據(jù)庫的方式匯總
本文實(shí)例匯總了ThinkPHP連接數(shù)據(jù)庫的幾種常用方式。分享給大家供大家參考。具體如下:
ThinkPHP內(nèi)置了抽象數(shù)據(jù)庫訪問層,把不同的數(shù)據(jù)庫操作封裝起來,我們只需要使用公共的Db類進(jìn)行操作,而無需針對(duì)不同的數(shù)據(jù)庫寫不同的代碼和底層實(shí)現(xiàn),Db類會(huì)自動(dòng)調(diào)用相應(yīng)的數(shù)據(jù)庫適配器來處理,目前的數(shù)據(jù)庫包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果應(yīng)用需要使用數(shù)據(jù)庫,必須配置數(shù)據(jù)庫連接信息,數(shù)據(jù)庫的配置文件有多種定義方式:
第一種:在項(xiàng)目配置文件里面定義
'DB_TYPE'=> 'mysql',
'DB_HOST'=> 'localhost',
'DB_NAME'=>'thinkphp',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PORT'=>'3306',
'DB_PREFIX'=>'think_',
// 其他項(xiàng)目配置參數(shù)………
);
系統(tǒng)推薦使用該種方式,因?yàn)橐话阋粋€(gè)項(xiàng)目的數(shù)據(jù)庫訪問配置是相同的,該方法系統(tǒng)在連接數(shù)據(jù)庫的時(shí)候會(huì)自動(dòng)獲取,無需手動(dòng)連接.
可以對(duì)每個(gè)項(xiàng)目定義不同的數(shù)據(jù)庫連接信息,還可以在調(diào)試配置文件(Conf/debug.php)里面定義調(diào)試數(shù)據(jù)庫的配置信息,如果在項(xiàng)目配置文件和調(diào)試模式配置文件里面同時(shí)定義了數(shù)據(jù)庫連接信息,那么在調(diào)試模式下面后者生效,部署模式下面前者生效.
第二種 使用DSN方式在初始化Db類的時(shí)候傳參數(shù)
$db = new Db($db_dsn);
該方式主要用于在控制器里面自己手動(dòng)連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個(gè)數(shù)據(jù)庫連接.
第三種 使用數(shù)組傳參數(shù)
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
$db = new Db($DSN);
該方式也是用于手動(dòng)連接數(shù)據(jù)庫的情況,或者用于創(chuàng)建多個(gè)數(shù)據(jù)庫連接.
第四種 在模型類里面定義
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
// 或者使用下面的定義
protected $connection = "mysql://username:passwd@localhost:3306/DbName";
如果在某個(gè)模型類里面定義了connection屬性,則在實(shí)例化模型對(duì)象的時(shí)候,會(huì)使用該數(shù)據(jù)庫連接信息進(jìn)行數(shù)據(jù)庫連接,通常用于某些數(shù)據(jù)表位于當(dāng)前數(shù)據(jù)庫連接之外的其它數(shù)據(jù)庫.
ThinkPHP并不是在一開始就會(huì)連接數(shù)據(jù)庫,而是在有數(shù)據(jù)查詢操作的時(shí)候才會(huì)去連接數(shù)據(jù)庫,額外的情況是,在系統(tǒng)第一次操作模型的時(shí)候,框架會(huì)自動(dòng)連接數(shù)據(jù)庫獲取相關(guān)模型類的數(shù)據(jù)字段信息,并緩存下來.
(字段緩存目錄:Runtime/Data/_fields)
ThinkPHP支持PDO方式,如果要使用PDO方式連接數(shù)據(jù)庫,可以參考下面的設(shè)置.
我們以項(xiàng)目配置文件定義為例來說明:
'DB_TYPE'=> 'pdo',
// 注意DSN的配置針對(duì)不同的數(shù)據(jù)庫有所區(qū)別 請(qǐng)參考PHP手冊(cè)PDO類庫部分
'DB_DSN'=> 'mysql:host=localhost;dbname=think',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PREFIX'=>'think_',
// 其他項(xiàng)目配置參數(shù)………
);
使用PDO方式的時(shí)候,要注意檢查是否開啟相關(guān)的PDO模塊,DB_DSN參數(shù)僅對(duì)PDO方式連接才有效.
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》及《ThinkPHP常用方法總結(jié)》
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
- thinkphp3.2.3框架動(dòng)態(tài)切換多數(shù)據(jù)庫的方法分析
- ThinkPHP5.0框架實(shí)現(xiàn)切換數(shù)據(jù)庫的方法分析
- ThinkPHP實(shí)現(xiàn)多數(shù)據(jù)庫連接的解決方法
- tp5(thinkPHP5)框架數(shù)據(jù)庫Db增刪改查常見操作總結(jié)
- tp5(thinkPHP5)框架實(shí)現(xiàn)多數(shù)據(jù)庫查詢的方法
- ThinkPHP連接數(shù)據(jù)庫及主從數(shù)據(jù)庫的設(shè)置教程
- thinkphp配置連接數(shù)據(jù)庫技巧
- tp5(thinkPHP5)框架連接數(shù)據(jù)庫的方法示例
- ThinkPHP3.2.3數(shù)據(jù)庫設(shè)置新特性
- thinkphp 框架數(shù)據(jù)庫切換實(shí)現(xiàn)方法分析
相關(guān)文章
PHP 進(jìn)程池與輪詢調(diào)度算法實(shí)現(xiàn)多任務(wù)的示例代碼
這篇文章主要介紹了PHP 進(jìn)程池與輪詢調(diào)度算法實(shí)現(xiàn)多任務(wù)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11關(guān)于PHP的相似度計(jì)算函數(shù):levenshtein的使用介紹
本篇文章小編將為大家介紹,關(guān)于PHP的相似度計(jì)算函數(shù) levenshtein的使用介紹,有需要的朋友可以參考一下2013-04-04destoon調(diào)用企業(yè)會(huì)員公司形象圖片的實(shí)現(xiàn)方法
這篇文章主要介紹了destoon調(diào)用企業(yè)會(huì)員公司形象圖片的實(shí)現(xiàn)方法,非常實(shí)用,需要的朋友可以參考下2014-08-08簡(jiǎn)單的php+mysql聊天室實(shí)現(xiàn)方法(附源碼)
這篇文章主要介紹了簡(jiǎn)單的php+mysql聊天室實(shí)現(xiàn)方法,詳細(xì)介紹了數(shù)據(jù)庫,框架頁面,登錄及信息的發(fā)布、展示功能實(shí)現(xiàn)技巧,并附帶了完整源碼供讀者下載參考,需要的朋友可以參考下2016-01-01laravel實(shí)現(xiàn)于語言包的完美切換方法
今天小編就為大家分享一篇laravel實(shí)現(xiàn)于語言包的完美切換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09基于laravel-admin 后臺(tái) 列表標(biāo)簽背景的使用方法
今天小編就為大家分享一篇基于laravel-admin 后臺(tái) 列表標(biāo)簽背景的使用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP連接MYSQL數(shù)據(jù)庫實(shí)例代碼
現(xiàn)在做的項(xiàng)目需要php連接mysql數(shù)據(jù)庫,雖然之前學(xué)過,但是現(xiàn)在基本上都給忘了,之后通過查找相關(guān)資料找到了解決方法,下面小編把具體方法分享在腳本之家平臺(tái)供大家學(xué)習(xí)2016-01-01