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