PHP設計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法實例分析
本文實例講述了PHP設計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法。分享給大家供大家參考,具體如下:
這個數(shù)據(jù)訪問對象模式主要就是描述了如何創(chuàng)建透明訪問數(shù)據(jù)源的對象,這種設計模式對于同時學過PHP和MySQL的人來說,是一個全新的和令人興奮的概念,并且這種設計模式的目的就是為了解決重復與數(shù)據(jù)源抽象化這兩種特定的問題。
我們可以先創(chuàng)建一個數(shù)據(jù)訪問對象設計模式的對象,這個數(shù)據(jù)訪問對象封裝了創(chuàng)建sQL調用、減少實例創(chuàng)建的復雜性和重復以及更新進程的智能方式,并且,這個數(shù)據(jù)訪問對象的使用者不會知道實際使用的表結構和數(shù)據(jù)庫引擎,此外,這個對象應用的方法應當使用邏輯參數(shù),并且應處理SQL語句的創(chuàng)建工作。
數(shù)據(jù)訪問對象模式的額外優(yōu)點是提供數(shù)據(jù)庫抽象層,現(xiàn)在,應用程序的主要處理代碼不再需要考慮數(shù)據(jù)庫引擎或表關系,調用這種對象的公共方法會返回任何數(shù)據(jù)類型,并且不用考慮內在SQL需要的類型。
然而,管理數(shù)據(jù)訪問對象類中簡單性的一個好辦法是創(chuàng)建父-子關系。
首先,創(chuàng)建一個基本的父對象。這個對象應當負責數(shù)據(jù)庫連接、抽象地執(zhí)行查詢以及與子對象通信。使用數(shù)據(jù)訪問對象設計模式時,最好開始就將一對一關系的子類與數(shù)據(jù)庫中的表相關聯(lián)。
并且,這些子類具有必不可少的信息,如表名和主鍵。此外,子類可能包含一些特定的公共方法,這些方法通過只對子類有意義的方式執(zhí)行父類的查詢。
例如,名為userAddress的子類可能包含一個getAddreddesByZip()方法。將該方法放入父DAO類是毫無邏輯意義的,并且會破壞這個父類希望實現(xiàn)的抽象性。
處理引用特定數(shù)據(jù)庫信息的實體時,最好的做法是創(chuàng)建一個數(shù)據(jù)訪問對象。
了解了上述內容之后,我們就來看下網(wǎng)上所有文章都會有的案例,場景如下:
- 設計一個BaseDao基類,實現(xiàn)數(shù)據(jù)庫操作基本的一些query,insert,update方法
- 在實際使用的過程中,繼承BaseDao,就可以直接調用基類的數(shù)據(jù)庫操作方法
代碼如下:
BaseDao.php
<?php //數(shù)據(jù)訪問對象模式 //將數(shù)據(jù)庫訪問層脫離出來 作為公用的訪問接口,方便用戶開放,是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 用戶數(shù)據(jù)表的數(shù)據(jù)操作,繼承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數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
Laravel 5框架學習之日期,Mutator 和 Scope
這篇文章主要介紹了Laravel 5框架學習之日期,Mutator 和 Scope的相關資料,需要的朋友可以參考下2015-04-04Zend Framework框架的校驗器InArray使用示例
這篇文章主要介紹了 zf框架的校驗器InArray使用示例框架的校驗器InArray使用示例,需要的朋友可以參考下2014-03-03淺談php中的循環(huán)while、do...while、for、foreach四種循環(huán)
下面小編就為大家?guī)硪黄獪\談php中的循環(huán)while、do...while、for、foreach四種循環(huán)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11