PHP數(shù)據(jù)源架構(gòu)模式之表入口模式實(shí)例分析
本文實(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ì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- PHP程序員簡(jiǎn)單的開(kāi)展服務(wù)治理架構(gòu)操作詳解(三)
- PHP程序員簡(jiǎn)單的開(kāi)展服務(wù)治理架構(gòu)操作詳解(二)
- PHP程序員簡(jiǎn)單的開(kāi)展服務(wù)治理架構(gòu)操作詳解(一)
- PHP架構(gòu)及原理知識(shí)點(diǎn)詳解
- thinkPHP5.0框架整體架構(gòu)總覽【應(yīng)用,模塊,MVC,驅(qū)動(dòng),行為,命名空間等】
- php代碼架構(gòu)的八點(diǎn)注意事項(xiàng)
- 四種php中webservice實(shí)現(xiàn)的簡(jiǎn)單架構(gòu)方法及實(shí)例
- php之深入理解架構(gòu)布局講解
相關(guān)文章
PHP調(diào)用JAVA的WebService簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)PHP調(diào)用JAVA的WebService簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-03-03
PHP中文URL編解碼(urlencode()rawurlencode()
PHP中對(duì)于URL進(jìn)行編碼,可以使用 urlencode() 或者 rawurlencode(),二者的區(qū)別是前者把空格編碼為 '+',而后者把空格編碼為 '%20',不過(guò)應(yīng)該注意的是,在編碼時(shí)應(yīng)該只對(duì)部分URL編碼,否則URL中的冒號(hào)和反斜杠也會(huì)被轉(zhuǎn)義。2010-07-07
php環(huán)境下利用session防止頁(yè)面重復(fù)刷新的具體實(shí)現(xiàn)
如何防止頁(yè)面重復(fù)刷新,在php環(huán)境下可以利用session來(lái)輕松實(shí)現(xiàn),下面是具體的代碼,需要的朋友可以參考下2014-01-01
中國(guó)站長(zhǎng)站 For Dede4.0 采集規(guī)則
中國(guó)站長(zhǎng)站 For Dede4.0 采集規(guī)則...2007-05-05
詳解PHP實(shí)現(xiàn)執(zhí)行定時(shí)任務(wù)
這篇文章主要介紹了PHP實(shí)現(xiàn)執(zhí)行定時(shí)任務(wù)的具體實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-12-12
自寫(xiě)的利用PDO對(duì)mysql數(shù)據(jù)庫(kù)增刪改查操作類
這篇文章主要給大家介紹了關(guān)于自寫(xiě)的利用PDO對(duì)mysql數(shù)據(jù)庫(kù)的增刪改查操作類的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-02-02
關(guān)于PHP session 存儲(chǔ)方式的詳細(xì)介紹
本篇文章是對(duì)PHP中的session存儲(chǔ)方式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

