欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年01月23日 10:59:18   作者:dongxie548  
這篇文章主要介紹了PHP數(shù)據(jù)源架構(gòu)模式之表入口模式,結(jié)合實例形式分析了PHP表入口模式的相關(guān)概念、原理、使用方法及操作注意事項,需要的朋友可以參考下

本文實例講述了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ù)等問題,不利于后期的維護,比較適合開發(fā)邏輯較為簡單的業(yè)務(wù),比如只有幾個用于展示企業(yè)信息的企業(yè)站等;

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

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

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

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

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

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

可以理解為對之前分散在各個頁面的sql語句進行封裝,一張表就是一個對象,該對象處理所有與該表有關(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è)計有所幫助。

相關(guān)文章

最新評論