溫馨提示×

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

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

PHP數(shù)據(jù)源架構(gòu)模式之表入口模式的示例分析

發(fā)布時(shí)間:2021-08-23 13:54:35 來(lái)源:億速云 閱讀:84 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了PHP數(shù)據(jù)源架構(gòu)模式之表入口模式的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

具體如下:

martin fowler在《企業(yè)應(yīng)用架構(gòu)模式》一書(shū)中將我們平常接觸到的應(yīng)用開(kāi)發(fā)分為三層:表現(xiàn)層、領(lǐng)域?qū)雍蛿?shù)據(jù)源層。

其中領(lǐng)域?qū)拥念I(lǐng)域邏輯模式有:事務(wù)腳本、領(lǐng)域模型以及表模塊。

1、事務(wù)腳本最容易理解也最易于開(kāi)發(fā),不過(guò)由于易造成代碼重復(fù)等問(wèn)題,不利于后期的維護(hù),比較適合開(kāi)發(fā)邏輯較為簡(jiǎn)單的業(yè)務(wù),比如只有幾個(gè)用于展示企業(yè)信息的企業(yè)站等;

2、領(lǐng)域模型是三種模式中最為復(fù)雜的模式,缺點(diǎn)顯而易見(jiàn),需要較高的學(xué)習(xí)成本,不過(guò)優(yōu)點(diǎn)也很鮮明,就是代碼清晰,復(fù)用率高,便于后期的維護(hù),比較適合用于復(fù)雜多變的應(yīng)用情形下;

3、表模塊模式則介于事物腳本和領(lǐng)域模型之間,我們開(kāi)發(fā)中小型項(xiàng)目時(shí)通常使用的都是表模塊模式。

好了,對(duì)于領(lǐng)域邏輯模式個(gè)人只有以上的粗淺理解,具體等以后加深理解了概念之后再來(lái)詳談。

這里想跟大家說(shuō)一說(shuō)數(shù)據(jù)源層的數(shù)據(jù)源架構(gòu)模式,主要有四種:表入口模式、行入口模式、活動(dòng)記錄和數(shù)據(jù)映射器。

今天先講最簡(jiǎn)單的表入口模式。

書(shū)中對(duì)表入口模式的定義為:充當(dāng)數(shù)據(jù)庫(kù)表訪問(wèn)入口的對(duì)象,一個(gè)實(shí)例處理表中的所有行。

可以理解為對(duì)之前分散在各個(gè)頁(yè)面的sql語(yǔ)句進(jìn)行封裝,一張表就是一個(gè)對(duì)象,該對(duì)象處理所有與該表有關(guān)的業(yè)務(wù)邏輯,很好的提高了代碼的復(fù)用性。

現(xiàn)在想起來(lái),當(dāng)初剛畢業(yè)那會(huì)兒,經(jīng)常使用表入口模式。

具體的實(shí)現(xiàn)方式參見(jiàn)代碼:

database.php

<?php
class Database{
 //只是為了演示,通常情況下數(shù)據(jù)庫(kù)的配置是會(huì)單獨(dú)寫(xiě)在配置文件中的
 private static $_dbConfig = array(
 'host' => '127.0.0.1',
 'username' => 'root',
 'pwd' => '',
 'dbname' => 'bussiness'
 );
 private static $_instance;
 public static function getInstance(){
 if(is_null(self::$_instance)){
  self::$_instance = new mysqli(self::$_dbConfig['host'], self::$_dbConfig['username'], self::$_dbConfig['pwd'], self::$_dbConfig['dbname']);
  if(self::$_instance->connect_errno){
  throw new Exception(self::$_instance->connect_error);
  }
 }
 return self::$_instance;
 }
}

person.php

<?php
require_once 'database.php';
class Person extends Database{
 public $instance;
 public $table = 'person';
 public function __construct(){
 $this->instance = Person::getInstance();
 }
 public function getPersonById($personId){
 $sql = "select * from $this->table where id=$personId";
 echo $sql;
 return $this->instance->query($sql);
 }
 /**其他的一些增刪改查操作方法...**/
}

index.php

<?php
require_once 'person.php';
$person = new Person();
var_dump($person->getPersonById(1)->fetch_assoc());
die();

運(yùn)行結(jié)果:

select * from person where id=1
array (size=2)
 'id' => string '1' (length=1)
 'name' => string 'ben' (length=3)

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“PHP數(shù)據(jù)源架構(gòu)模式之表入口模式的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

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

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

php
AI