1. 程式人生 > 程式設計 >PHP資料來源架構模式之表入口模式例項分析

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程式設計有所幫助。