您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關怎么在PHP項目中實現一個數據庫單例模式,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
單例模式顧名思義,就是只有一個實例。
作為對象的創建模式, 單例模式確保某一個類只有一個實例,而且自行實例化并向整個系統提供這個實例,這個類我們稱之為單例類。
單例模式的要點有三個:
一是某個類只能有一個實例;
二是它必須自行創建這個實例;
三是它必須自行向整個系統提供這個實例。
下面我們討論下為什么要使用PHP單例模式?
多數人都是從單例模式的字面上的意思來理解它的用途, 認為這是對系統資源的節省, 可以避免重復實例化, 是一種"計劃生育". 而PHP每次執行完頁面都是會從內存中清理掉所有的資源. 因而PHP中的單例實際每次運行都是需要重新實例化的, 這樣就失去了單例重復實例化的意義了. 單單從這個方面來說, PHP的單例的確有點讓各位失望. 但是單例僅僅只有這個功能和應用嗎? 答案是否定的,我們一起來看看。
1. php的應用主要在于數據庫應用, 所以一個應用中會存在大量的數據庫操作, 在使用面向對象的方式開發時(廢話), 如果使用單例模式, 則可以避免大量的new 操作消耗的資源。
2. 如果系統中需要有一個類來全局控制某些配置信息, 那么使用單例模式可以很方便的實現. 這個可以參看zend Framework的FrontController部分。
3. 在一次頁面請求中, 便于進行調試, 因為所有的代碼(例如數據庫操作類db)都集中在一個類中, 我們可以在類中設置鉤子, 輸出日志,從而避免到處var_dump, echo。
class db { public static $cennct = null; private function __construct(){return false;} private function conn(){ $pdo = new PDO('mysql:host=localhost;dbname=dbname','root',''); $pdo->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true); $pdo->query('set names utf8'); return $pdo; } public static function getdb(){ if(self::$cennct == null ) self::$cennct = self::conn(); return true; } protected function fetch($sql,$param=array()){ $this->getdb(); $tmp = self::$cennct->prepare($sql); $tmp->execute($param); return $tmp->fetch(PDO::FETCH_ASSOC); } protected function fetchAll($sql,$param=array()){ $this->getdb(); $tmp = self::$cennct->prepare($sql); $tmp->execute($param); return $tmp->fetchAll(PDO::FETCH_ASSOC); } protected function execute($sql,$param=array()){ $this->getdb(); $tmp = self::$cennct->prepare($sql); return $tmp->execute($param); } }
看完上述內容,你們對怎么在PHP項目中實現一個數據庫單例模式有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。