成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

PHP設(shè)計(jì)模式-DAO (Data Access Objects) 數(shù)據(jù)訪問對象模式

z2xy / 2542人閱讀

整理一下自己的學(xué)習(xí)Aaron Saray 寫的PHP設(shè)計(jì)模式一些demo和自己的理解。大佬看完如果發(fā)現(xiàn)鄙人理解有誤請立即指出,感謝拍磚,跪求鞭打

/**
 * DAO (Data Access Objects) 數(shù)據(jù)訪問對象
 * -------------------------------------
 * ** 來自說明 **
 *
 * 數(shù)據(jù)訪問對象設(shè)計(jì)模式描述了如何創(chuàng)建提供透明訪問任何數(shù)據(jù)源的對象
 *
 * 目的是解決下列兩種特定的問題:
 *     1. 重復(fù)
 *  2. 數(shù)據(jù)源抽象化
 *  數(shù)據(jù)訪問對象模式提供數(shù)據(jù)庫抽象層
 *  現(xiàn)在,應(yīng)用程序的主要處理代碼不再考慮數(shù)據(jù)庫引擎或表關(guān)系
 *  調(diào)用這種對象的公共方法會返回任何數(shù)據(jù)類型,不用考慮內(nèi)在SQL所需的類型
 * 
 * ===================================== 
 * ** 應(yīng)用場景 **
 *
 * 數(shù)據(jù)訪問
 * 
 * -------------------------------------
 * 
 * @version ${Id}$
 * @author Shaowei Pu <[email protected]>
 */

abstract class baseDao{
    /**
     * [$_connection 連接對象]
     * @var [type]
     */
    private $_connection;

    /**
     * [__construct 實(shí)例化數(shù)據(jù)庫連接]
     * @author         Shaowei Pu 
     * @CreateTime    2017-02-22T17:52:04+0800
     */
    public function __construct(){
        try{        
            $this->_connection = new PDO("mysql:dbname=mysql;host=localhost","root","pushaowei");
            $this->_connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        }catch(PDOException $e){
            die("error:".$e->getMessage());
        }   
    }
    /**
     * [feach description]
     * @author         Shaowei Pu 
     * @CreateTime    2017-02-22T18:01:48+0800
     * @return                              [type] [description]
     */
    public function fetch( $value , $key = ""){
        // SQL START
        $sql = "SELECT * FROM ".$this->_tablename." WHERE ".$key." = "".$value.""";
        // 輸出
        $dispose = $this->_connection->query($sql);
        return $dispose->fetch(PDO::FETCH_ASSOC);        
    }

}
class selectHandle extends baseDao{
    /**
     * [$_tablename 得到表名]
     * @var string
     */
    protected $_tablename = "db";

    /**
     * [getValue description]
     * @author         Shaowei Pu 
     * @CreateTime    2017-02-22T18:06:58+0800
     * @param                               [type] $value [description]
     * @return                              [type]        [description]
     */
    public function getDbValue( $value ){
        $result = parent::fetch( $value, "Host" );
        return $result;
    }
}

$select = new selectHandle;
var_dump($select->getDbValue("localhost"));

/* 
+----------------------------------------------------------------------
|    array (size=22)
|      "Host" => string "localhost" (length=9)
|      "Db" => string "sys" (length=3)
|      "User" => string "mysql.sys" (length=9)
|      "Select_priv" => string "N" (length=1)
|      "Insert_priv" => string "N" (length=1)
|      "Update_priv" => string "N" (length=1)
|      "Delete_priv" => string "N" (length=1)
|      "Create_priv" => string "N" (length=1)
|      "Drop_priv" => string "N" (length=1)
|      "Grant_priv" => string "N" (length=1)
|      "References_priv" => string "N" (length=1)
|      "Index_priv" => string "N" (length=1)
|      "Alter_priv" => string "N" (length=1)
|      "Create_tmp_table_priv" => string "N" (length=1)
|      "Lock_tables_priv" => string "N" (length=1)
|      "Create_view_priv" => string "N" (length=1)
|      "Show_view_priv" => string "N" (length=1)
|      "Create_routine_priv" => string "N" (length=1)
|      "Alter_routine_priv" => string "N" (length=1)
|      "Execute_priv" => string "N" (length=1)
|      "Event_priv" => string "N" (length=1)
|      "Trigger_priv" => string "Y" (length=1)
+----------------------------------------------------------------------
*/



文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81691.html

相關(guān)文章

  • PHP設(shè)計(jì)模式-DAO (Data Access Objects) 數(shù)據(jù)訪問對象模式

    整理一下自己的學(xué)習(xí)Aaron Saray 寫的PHP設(shè)計(jì)模式一些demo和自己的理解。大佬看完如果發(fā)現(xiàn)鄙人理解有誤請立即指出,感謝拍磚,跪求鞭打 /** * DAO (Data Access Objects) 數(shù)據(jù)訪問對象 * ------------------------------------- * ** 來自說明 ** * * 數(shù)據(jù)訪問對象設(shè)計(jì)模式描述了如何創(chuàng)建提供透明訪問任何...

    stonezhu 評論0 收藏0
  • PHP設(shè)計(jì)模式-DAO (Data Access Objects) 數(shù)據(jù)訪問對象模式

    整理一下自己的學(xué)習(xí)Aaron Saray 寫的PHP設(shè)計(jì)模式一些demo和自己的理解。大佬看完如果發(fā)現(xiàn)鄙人理解有誤請立即指出,感謝拍磚,跪求鞭打 /** * DAO (Data Access Objects) 數(shù)據(jù)訪問對象 * ------------------------------------- * ** 來自說明 ** * * 數(shù)據(jù)訪問對象設(shè)計(jì)模式描述了如何創(chuàng)建提供透明訪問任何...

    shadajin 評論0 收藏0
  • Spring體系常用項(xiàng)目一覽

    摘要:的面向的異常遵從通用的異常層次結(jié)構(gòu)。比如以前常用的框架,現(xiàn)在常用的框架包含許多項(xiàng)目,下面挑一些最常用的出來總結(jié)一下。狀態(tài)是流程中事件發(fā)生的地點(diǎn),在流程中通過轉(zhuǎn)移的方式從一個(gè)狀態(tài)到另一個(gè)狀態(tài),流程的當(dāng)前狀況稱為流程數(shù)據(jù)。 如今做Java尤其是web幾乎是避免不了和Spring打交道了,但是Spring是這樣的大而全,新鮮名詞不斷產(chǎn)生,學(xué)起來給人一種凌亂的感覺,我就在這里總結(jié)一下,理順頭緒...

    OnlyLing 評論0 收藏0
  • Java中的DAO模式

    摘要:此的功能是從應(yīng)用程序中隱藏在底層存儲機(jī)制中執(zhí)行操作所涉及的所有復(fù)雜性。這正是模式試圖解決的問題。將模式與一起使用開發(fā)人員普遍認(rèn)為的發(fā)布將模式的功能降級為零,因?yàn)樵撃J街皇菍?shí)體經(jīng)理提供的另一層抽象和復(fù)雜性。在這種情況下,模式有其自己的位置。 案例概述 數(shù)據(jù)訪問對象(DAO)模式是一種結(jié)構(gòu)模式,它允許我們使用抽象API將應(yīng)用程序/業(yè)務(wù)層與持久層(通常是關(guān)系數(shù)據(jù)庫,但它可以是任何其他持久性機(jī)...

    TIGERB 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<