本文實例講述了PHP設計模式之數據訪問對象模式(DAO)原理與用法。分享給大家供大家參考,具體如下:
這個數據訪問對象模式主要就是描述了如何創建透明訪問數據源的對象,這種設計模式對于同時學過PHP和MySQL的人來說,是一個全新的和令人興奮的概念,并且這種設計模式的目的就是為了解決重復與數據源抽象化這兩種特定的問題。
我們可以先創建一個數據訪問對象設計模式的對象,這個數據訪問對象封裝了創建sQL調用、減少實例創建的復雜性和重復以及更新進程的智能方式,并且,這個數據訪問對象的使用者不會知道實際使用的表結構和數據庫引擎,此外,這個對象應用的方法應當使用邏輯參數,并且應處理SQL語句的創建工作。
數據訪問對象模式的額外優點是提供數據庫抽象層,現在,應用程序的主要處理代碼不再需要考慮數據庫引擎或表關系,調用這種對象的公共方法會返回任何數據類型,并且不用考慮內在SQL需要的類型。
然而,管理數據訪問對象類中簡單性的一個好辦法是創建父-子關系。
首先,創建一個基本的父對象。這個對象應當負責數據庫連接、抽象地執行查詢以及與子對象通信。使用數據訪問對象設計模式時,最好開始就將一對一關系的子類與數據庫中的表相關聯。
并且,這些子類具有必不可少的信息,如表名和主鍵。此外,子類可能包含一些特定的公共方法,這些方法通過只對子類有意義的方式執行父類的查詢。
例如,名為userAddress的子類可能包含一個getAddreddesByZip()方法。將該方法放入父DAO類是毫無邏輯意義的,并且會破壞這個父類希望實現的抽象性。
處理引用特定數據庫信息的實體時,最好的做法是創建一個數據訪問對象。
了解了上述內容之后,我們就來看下網上所有文章都會有的案例,場景如下:
- 設計一個BaseDao基類,實現數據庫操作基本的一些query,insert,update方法
- 在實際使用的過程中,繼承BaseDao,就可以直接調用基類的數據庫操作方法
代碼如下:
BaseDao.php
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<?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); } } |
1
2
3
4
5
6
7
8
9
10
11
|
//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程序設計有所幫助。
原文鏈接:https://blog.csdn.net/luyaran/article/details/82884581