溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在PHP中使用數(shù)據(jù)訪問對象模式

發(fā)布時(shí)間:2021-04-02 14:47:33 來源:億速云 閱讀:177 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)怎么在PHP中使用數(shù)據(jù)訪問對象模式,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

首先,創(chuàng)建一個(gè)基本的父對象。這個(gè)對象應(yīng)當(dāng)負(fù)責(zé)數(shù)據(jù)庫連接、抽象地執(zhí)行查詢以及與子對象通信。使用數(shù)據(jù)訪問對象設(shè)計(jì)模式時(shí),最好開始就將一對一關(guān)系的子類與數(shù)據(jù)庫中的表相關(guān)聯(lián)。

并且,這些子類具有必不可少的信息,如表名和主鍵。此外,子類可能包含一些特定的公共方法,這些方法通過只對子類有意義的方式執(zhí)行父類的查詢。

例如,名為userAddress的子類可能包含一個(gè)getAddreddesByZip()方法。將該方法放入父DAO類是毫無邏輯意義的,并且會破壞這個(gè)父類希望實(shí)現(xiàn)的抽象性。

處理引用特定數(shù)據(jù)庫信息的實(shí)體時(shí),最好的做法是創(chuàng)建一個(gè)數(shù)據(jù)訪問對象。

了解了上述內(nèi)容之后,我們就來看下網(wǎng)上所有文章都會有的案例,場景如下:

  1. 設(shè)計(jì)一個(gè)BaseDao基類,實(shí)現(xiàn)數(shù)據(jù)庫操作基本的一些query,insert,update方法

  2. 在實(shí)際使用的過程中,繼承BaseDao,就可以直接調(diào)用基類的數(shù)據(jù)庫操作方法

代碼如下:

BaseDao.php

<?php
//數(shù)據(jù)訪問對象模式
//將數(shù)據(jù)庫訪問層脫離出來 作為公用的訪問接口,方便用戶開放,是php中常用的一種設(shè)計(jì)模式
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();

看完上述內(nèi)容,你們對怎么在PHP中使用數(shù)據(jù)訪問對象模式有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI