- 相關(guān)推薦
PHP和DAO設(shè)計模式
DAO(Data Access Object,數(shù)據(jù)存取對象)設(shè)計模式對于從PHP和MySQL教程一步步走過來的人來說是一個新的概念。我們的編碼中的一大部分就是用來解決數(shù)據(jù)(庫)獲取和操作。隨著大數(shù)據(jù)的來臨,和數(shù)據(jù)分析方法的進(jìn)步,數(shù)據(jù)操作越來越重要。
DAO設(shè)計模式旨在解決兩個問題:重復(fù)、和數(shù)據(jù)源抽象。
重復(fù):在程序中我們一般會寫一句SQL語句來在數(shù)據(jù)庫中創(chuàng)造一個條目。之后又寫一個SQL語句來更新某一欄。不斷地重復(fù)寫SQL既無聊又不優(yōu)雅。
事實上,我們?nèi)绻肈AO設(shè)計模式來實現(xiàn)的話,一個數(shù)據(jù)存取對象會用來封裝SQL的創(chuàng)建過程,減少復(fù)雜性和重復(fù)性。它應(yīng)該不用區(qū)分具體的表結(jié)構(gòu)和數(shù)據(jù)庫引擎。
數(shù)據(jù)源抽象:另一個優(yōu)勢就是數(shù)據(jù)層的抽象,F(xiàn)在你的邏輯代碼不用再擔(dān)心數(shù)據(jù)庫引擎和表的關(guān)系。調(diào)用他們的公共方法可以返回任意類型的數(shù)據(jù),無論底層需要怎樣的SQL。
但是程序員不要過度設(shè)計DAO。簡化DAO的設(shè)計就好,不要增加不需要的功能。
在github上有一些使用了DAO模式的Repo,有的簡單,有的過度設(shè)計了。簡單地說,實現(xiàn)上我們需要一個抽象類(baseDAO)和一些繼承了它的實體類(比如userDAO)。
在baseDAO中需要定義兩個公共函數(shù):fetch和update,分別獲得一行數(shù)據(jù)和更新一個數(shù)組。還定義一些私有的函數(shù)比如鏈接數(shù)據(jù)庫,還有私有的數(shù)據(jù)比如當(dāng)前表的主鍵和表明。
在userDAO繼承baseDAO的時候,需要聲明私有數(shù)據(jù)比如主鍵和表明,然后在baseDAO的fetch和update的基礎(chǔ)上自定義一些新的公共函數(shù)。這樣做的好處是把生成SQL的工作全部封裝在兩個抽象類的公共函數(shù)之中,userDAO以及其他的更多DAO只是調(diào)用這一函數(shù)而已。
需要更多的數(shù)據(jù)存取操作的時候,我們就基于baseDAO新建一個userDAO或者itemDAO,然后實例化這一對象,這就是DAO設(shè)計模式。
【PHP和DAO設(shè)計模式】相關(guān)文章:
java設(shè)計模式:DAO模式08-18
PHP中的設(shè)計模式詳解06-02
PHP策略模式定義與用法08-25
PHP 和 MYSQL09-23
PHP中php://input和$-POST的區(qū)別08-26
Java和PHP的區(qū)別09-09
java和PHP對比09-03
教學(xué)設(shè)計的探究原理和模式的經(jīng)典范文08-07
php中php://input和$-POST有什么不同07-23
java設(shè)計模式:工廠模式11-07