java中service層用法 java分層biz層,entity層dao層util層……主要做什么?
java分層biz層,entity層dao層util層……主要做什么?這些不是所謂的分層。要說分層,也是動作、服務(wù)、道三層。Biz和util只是用來存儲一些工具的文件夾。它們都起輔助作用。實際上,順序
java分層biz層,entity層dao層util層……主要做什么?
這些不是所謂的分層。要說分層,也是動作、服務(wù)、道三層。Biz和util只是用來存儲一些工具的文件夾。它們都起輔助作用。實際上,順序是動作調(diào)用服務(wù)調(diào)用Dao,然后返回的數(shù)據(jù)從Dao到服務(wù),再到動作,再到頁面顯示
這體現(xiàn)了一種分層思想,服務(wù)負責業(yè)務(wù)邏輯,Dao負責數(shù)據(jù)訪問。以注冊用戶的功能為例,服務(wù)層在處理異常的同時,負責檢查用戶名是否有保留字和是否被使用,然后將信息寫入數(shù)據(jù)庫,再生成權(quán)限等關(guān)聯(lián)信息也寫入數(shù)據(jù)庫。這一系列動作是業(yè)務(wù)邏輯。服務(wù)層負責實現(xiàn),但它不應(yīng)該關(guān)心底層是使用MySQL還是Oracle,也不應(yīng)該拼接SQL語句。Dao層的代碼只與數(shù)據(jù)庫交互。例如,如果服務(wù)層想要添加用戶記錄,它將執(zhí)行insert語句。如果它想檢查用戶是否存在,它將執(zhí)行select語句。
java中dao層和service層的區(qū)別是什么?
這主要取決于您的項目:
例如,如果項目中使用hibernate,以后可能會切換到mybatis,那么Dao需要使用該接口。這不會影響上層代碼的更改。
另一個例子是,項目是一個單一的應(yīng)用程序。任何代碼修改都需要重新編譯整個項目,因此不需要接口。如果項目是由模塊編譯和部署的,那么可以使用接口解耦。假設(shè)修改了Dao,只需要重新編譯和部署Dao模塊,而不影響上層模塊。
此外,如果項目團隊中有許多新手,簡單的代碼結(jié)構(gòu)可能更合適。復(fù)雜項目結(jié)構(gòu)的學(xué)習(xí)成本較高。
如果工程進度非常緊迫,我們可以用簡單粗暴的方式用經(jīng)濟成本來說明原因。
使用接口的成本是不使用接口的成本(包括后續(xù)維護成本)。
如果項目變化很大,部署了模塊,項目不急,使用接口的成本比不使用接口的成本低,雖然早期不使用接口似乎更簡單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢!