欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP設計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法實例分析

 更新時間:2019年12月12日 11:18:37   作者:luyaran  
這篇文章主要介紹了PHP設計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法,結合實例形式分析了PHP數(shù)據(jù)訪問對象模式的概念、原理、用法及操作注意事項,需要的朋友可以參考下

本文實例講述了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)上所有文章都會有的案例,場景如下:

  1. 設計一個BaseDao基類,實現(xiàn)數(shù)據(jù)庫操作基本的一些query,insert,update方法
  2. 在實際使用的過程中,繼承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程序設計有所幫助。

相關文章

最新評論