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