PHP資料來源架構模式之表入口模式例項分析
本文例項講述了PHP資料來源架構模式之表入口模式。分享給大家供大家參考,具體如下:
martin fowler在《企業應用架構模式》一書中將我們平常接觸到的應用開發分為三層:表現層、領域層和資料來源層。
其中領域層的領域邏輯模式有:事務指令碼、領域模型以及表模組。
1、事務指令碼最容易理解也最易於開發,不過由於易造成程式碼重複等問題,不利於後期的維護,比較適合開發邏輯較為簡單的業務,比如只有幾個用於展示企業資訊的企業站等;
2、領域模型是三種模式中最為複雜的模式,缺點顯而易見,需要較高的學習成本,不過優點也很鮮明,就是程式碼清晰,複用率高,便於後期的維護,比較適合用於複雜多變的應用情形下;
3、表模組模式則介於事物指令碼和領域模型之間,我們開發中小型專案時通常使用的都是表模組模式。
好了,對於領域邏輯模式個人只有以上的粗淺理解,具體等以後加深理解了概念之後再來詳談。
這裡想跟大家說一說資料來源層的資料來源架構模式,主要有四種:表入口模式、行入口模式、活動記錄和資料對映器。
今天先講最簡單的表入口模式。
書中對錶入口模式的定義為:充當資料庫表訪問入口的物件,一個例項處理表中的所有行。
可以理解為對之前分散在各個頁面的sql語句進行封裝,一張表就是一個物件,該物件處理所有與該表有關的業務邏輯,很好的提高了程式碼的複用性。
現在想起來,當初剛畢業那會兒,經常使用表入口模式。
具體的實現方式參見程式碼:
database.php
<?php class Database{ //只是為了演示,通常情況下資料庫的配置是會單獨寫在配置檔案中的 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();
執行結果:
select * from person where id=1 array (size=2) 'id' => string '1' (length=1) 'name' => string 'ben' (length=3)
更多關於PHP相關內容感興趣的讀者可檢視本站專題:《php面向物件程式設計入門教程》、《PHP陣列(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算子用法總結》、《php字串(string)用法總結》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》
希望本文所述對大家PHP程式設計有所幫助。