本文實(shí)例講述了PHP數(shù)據(jù)源架構(gòu)模式之表入口模式。分享給大家供大家參考,具體如下:
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)
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門(mén)教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
標(biāo)簽:鎮(zhèn)江 宜賓 寶雞 黃南 湛江 南陽(yáng) 銅川 婁底
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實(shí)例分析》,本文關(guān)鍵詞 PHP,數(shù)據(jù)源,架構(gòu),模式,之表,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。