主頁 > 知識庫 > PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實例分析

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

熱門標(biāo)簽:山西探意電話機器人 揚州地圖標(biāo)注app 昭通辦理400電話 青島語音外呼系統(tǒng)招商 岳陽外呼型呼叫中心系統(tǒng)在哪里 騰訊外呼管理系統(tǒng) 山西回?fù)芡夂粝到y(tǒng) 河南電銷卡外呼系統(tǒng)哪家強 百應(yīng)電話機器人服務(wù)

本文實例講述了PHP數(shù)據(jù)源架構(gòu)模式之表入口模式。分享給大家供大家參考,具體如下:

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

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

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

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

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

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

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

今天先講最簡單的表入口模式。

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

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

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

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

database.php

?php
class Database{
 //只是為了演示,通常情況下數(shù)據(jù)庫的配置是會單獨寫在配置文件中的
 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();

運行結(jié)果:

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

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計有所幫助。

您可能感興趣的文章:
  • PHP程序員簡單的開展服務(wù)治理架構(gòu)操作詳解(三)
  • PHP程序員簡單的開展服務(wù)治理架構(gòu)操作詳解(二)
  • PHP程序員簡單的開展服務(wù)治理架構(gòu)操作詳解(一)
  • PHP架構(gòu)及原理知識點詳解
  • thinkPHP5.0框架整體架構(gòu)總覽【應(yīng)用,模塊,MVC,驅(qū)動,行為,命名空間等】
  • php代碼架構(gòu)的八點注意事項
  • 四種php中webservice實現(xiàn)的簡單架構(gòu)方法及實例
  • php之深入理解架構(gòu)布局講解

標(biāo)簽:鎮(zhèn)江 宜賓 寶雞 黃南 湛江 南陽 銅川 婁底

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實例分析》,本文關(guān)鍵詞  PHP,數(shù)據(jù)源,架構(gòu),模式,之表,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實例分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章