本文實例講述了PHP設計模式之數據訪問對象模式(DAO)原理與用法。分享給大家供大家參考,具體如下:
這個數據訪問對象模式主要就是描述了如何創建透明訪問數據源的對象,這種設計模式對于同時學過PHP和MySQL的人來說,是一個全新的和令人興奮的概念,并且這種設計模式的目的就是為了解決重復與數據源抽象化這兩種特定的問題。
我們可以先創建一個數據訪問對象設計模式的對象,這個數據訪問對象封裝了創建sQL調用、減少實例創建的復雜性和重復以及更新進程的智能方式,并且,這個數據訪問對象的使用者不會知道實際使用的表結構和數據庫引擎,此外,這個對象應用的方法應當使用邏輯參數,并且應處理SQL語句的創建工作。
數據訪問對象模式的額外優點是提供數據庫抽象層,現在,應用程序的主要處理代碼不再需要考慮數據庫引擎或表關系,調用這種對象的公共方法會返回任何數據類型,并且不用考慮內在SQL需要的類型。
然而,管理數據訪問對象類中簡單性的一個好辦法是創建父-子關系。
首先,創建一個基本的父對象。這個對象應當負責數據庫連接、抽象地執行查詢以及與子對象通信。使用數據訪問對象設計模式時,最好開始就將一對一關系的子類與數據庫中的表相關聯。
并且,這些子類具有必不可少的信息,如表名和主鍵。此外,子類可能包含一些特定的公共方法,這些方法通過只對子類有意義的方式執行父類的查詢。
例如,名為userAddress的子類可能包含一個getAddreddesByZip()方法。將該方法放入父DAO類是毫無邏輯意義的,并且會破壞這個父類希望實現的抽象性。
處理引用特定數據庫信息的實體時,最好的做法是創建一個數據訪問對象。
了解了上述內容之后,我們就來看下網上所有文章都會有的案例,場景如下:
- 設計一個BaseDao基類,實現數據庫操作基本的一些query,insert,update方法
- 在實際使用的過程中,繼承BaseDao,就可以直接調用基類的數據庫操作方法
代碼如下:
BaseDao.php
?php
//數據訪問對象模式
//將數據庫訪問層脫離出來 作為公用的訪問接口,方便用戶開放,是php中常用的一種設計模式
class BaseDao {
private $db;
public function __construct($config) {
$this->db = mysql_connect($config['user'], $config['pass'], $config['host']);
mysql_select_db($config['database'], $this->db);
}
public function query($sql) {
return mysql_query($sql, $this->db);
}
}
//UserDao 用戶數據表的數據操作,繼承BaseDao
?php
include("UserDao.php");
class UserDao extends BaseDao {
public function addUser() {
$sql = "INSERT INTO user (username) VALUES ('initphp')";
return $this->query($sql);
}
}
$UserDao = new UserDao;
$UserDao->addUser();
好啦,本次記錄就到這里了。
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- PHP中數據庫單例模式的實現代碼分享
- php設計模式 DAO(數據訪問對象模式)
- 淺析php設計模式之數據對象映射模式
- PHP基于單例模式實現的數據庫操作基類
- PHP的中使用非緩沖模式查詢數據庫的方法
- PHP實現的數據對象映射模式詳解
- PHP單例模式應用示例【多次連接數據庫只實例化一次】
- PHP單例模式數據庫連接類與頁面靜態化實現方法
- PHP數據對象映射模式實例分析
- PHP數據源架構模式之表入口模式實例分析