通常java都是三層架構 數據訪問層(dao) 業務邏輯層(biz 或者services) 界面層(ui) action 是業務層的一部分,是一個管理器 (總開關)(做用是取掉轉)(取出前臺界面的數據,調用biz方法,轉發到下一個action或者頁面) 模型成(model)通常是實體對象(把現實的的事物變成java中的對象)做用是一暫時存儲數據方便持久化(存入數據庫或者寫入文件)而是 做爲一個包裹封裝一些數據來在不一樣的層以及各類java對象中使用 dao是數據訪問層 就是用來訪問數據庫實現數據的持久化(把內存中的數據永久保存到硬盤中) 前端
Dao主要作數據庫的交互工做 Model 是模型 存放你的實體類 Service 作相應的業務邏輯處理 Action是一個控制器 java
首先解釋面上意思,service是業務層,dao是數據訪問層。 spring
呵呵,這個問題我曾經也有過,記得之前剛學編程的時候,都是在service裏直接調用dao,service裏面就new一個dao類對象,調用,其餘有意義的事沒作,也不明白有這個有什麼用,參加工做久了之後就會知道,業務纔是工做中的重中之重。 數據庫
咱們都知道,標準主流如今的編程方式都是採用MVC綜合設計模式,MVC自己不屬於設計模式的一種,它描述的是一種結構,最終目的達到解耦,解耦說的意思是你更改某一層代碼,不會影響我其餘層代碼,若是你會像spring這樣的框架,你會了解面向接口編程,表示層調用控制層,控制層調用業務層,業務層調用數據訪問層。初期也許都是new對象去調用下一層,好比你在業務層new一個DAO類的對象,調用DAO類方法訪問數據庫,這樣寫是不對的,由於在業務層中是不該該含有具體對象,最多隻能有引用,若是有具體對象存在,就耦合了。當那個對象不存在,我還要修改業務的代碼,這不符合邏輯。比如主板上內存壞了,我換內存,不必連主板一塊兒換。我不用知道內存是哪家生產,不用知道多大容量,只要是內存均可以插上這個接口使用。這就是MVC的意義。 編程
接下來講你感受service的意義,其實由於你如今作東西分層次不是那麼嚴格,在一個大家作東西業務自己也少,舉個最簡單的例子,你作一個分頁的功能,數據1000條,你20條在一個頁,你能夠把這個功能寫成工具類封裝起來,而後在業務層裏調用這個封裝的方法,這纔是業務裏真正幹得事,只要沒訪問數據庫的,都要在業務裏寫。 再有不明白的追問,這是經驗問題,呵呵,其實之後你就會懂。只是剛開始寫的代碼都是有個請求,我就去數據庫取,業務幾乎沒有。 設計模式
<span style="color:#333333">怎麼說呢,我不是理論帝。架構
因此我講講本身的理解 比說你如今用的是SSH框架,作一個用戶模塊: 一、假設如今你作這個功能會用到user表和權限表,那麼你前臺的頁面訪問action,action再去調用用戶模塊service,用戶模塊service判斷你是操做user表仍是權限表,若是你操做的是user表則service的實現類就去調用userDAO。若是是操做的是權限表則調用權限的DAO 框架
二、也就是說DAO必定是和數據庫的每張表一一對應,而service則不是。明白的沒?其實你一個項目一個service和一個DAO其實也同樣能夠操做數據庫,只不過那要是表很是多,出問題了,那找起來多麻煩,並且太亂了 模塊化
三、好處就是你的整個項目很是系統化,和數據庫的表能一致,並且功能模塊化,這樣之後維護或者改錯比較容易,性能也高一些</span> 工具
<span style="color:#333333">
</span>
<span style="color:#333333">
</span>
<span style="color:#333333">
</span>
簡單的說DAO層是跟數據庫打交道的,service層是處理一些業務流程的, 至於你說的爲何要用service層封裝,我認爲:通常來講,某一個程序的有些業務流程須要鏈接數據庫,有些不須要與數據庫打交道而直接是一些業務處理,這樣就須要咱們整合起來到service中去,這樣能夠起到一個更好的開發與維護的做用,同時也是MVC設計模式中model層功能的體現 最基本的分層方式,結合了SSH架構。modle層就是對應的數據庫表的實體類(如User類)。
Dao層,通常能夠再分爲***Dao接口和***DaoImpl實現類,如userDao接口和userDaoImpl實現類,接口負責定義數據庫curd的操做方法,實現類負責具體的實現,即實現Dao接口定義的方法。Service層,引用對應的Dao層數據庫操做,在這裏能夠編寫本身須要的代碼(好比簡單的判斷),也能夠再細分爲Service接口和ServiceImpl實現類。
Action層:引用對應的Service層實現業務邏輯,在這裏結合Struts的配置文件,跳轉到指定的頁面,固然也能接受頁面傳遞的請求數據,也能夠作些計算處理、前端輸入合法性檢驗(前端可修改網頁繞過前端合法性檢驗,需在後臺加一層)。
Action像是服務員,顧客點什麼菜,菜上給幾號桌,都是ta的職責;Service是廚師,action送來的菜單上的菜全是ta作的;Dao是廚房的小工,和原材料(經過hibernate操做數據庫)打交道的事情全是ta管。
對象的調用流程:JSP—Action—Service—DAO—Hibernate—數據庫。