天天看點

[Java]Java分層概念

service是業務層 

action層即作為控制器

DAO (Data Access Object) 資料通路

1.JAVA中Action層, Service層 ,modle層 和 Dao層的功能區分?(下面所描述的service層就是biz) 

      首先這是現在最基本的分層方式,結合了SSH架構。modle層就是對應的資料庫表的實體類。

Dao層是使用了Hibernate連接配接資料庫、操作資料庫(增删改查)。

Service(biz)層:引用對應的Dao資料庫操作,在這裡可以編寫自己需要的代碼(比如簡單的判斷)。

Action層:引用對應的Service(biz)層,在這裡結合Struts的配置檔案,跳轉到指定的頁面,當然也能接受頁面傳遞的請求資料,也可以做些計算處理。

以上的Hibernate,Struts,都需要注入到Spring的配置檔案中,Spring把這些聯系起來,成為一個整體。

其他答案: 

  一般java都是三層架構 資料通路層(dao) 業務邏輯層(biz 或者services) 界面層(ui) 

action 是業務層的一部分,是一個管理器 (總開關)(作用是取掉轉)(取出前台界面的資料,調用biz方法,轉發到下一個action或者頁面)    

模型成(model)一般是實體對象(把現實的的事物變成java中的對象)作用是一暫時存儲資料友善持久化(存入資料庫或者寫入檔案)而是 作為一個包裹封裝一些資料來在不同的層以及各種java對象中使用   

dao是資料通路層  就是用來通路資料庫實作資料的持久化(把記憶體中的資料永久儲存到硬碟中 其他答案:  

Action是一個控制器 Dao主要做資料庫的互動工作 Modle 是模型 存放你的實體類 Biz 做相應的業務邏輯處理    

2.java中dao層和biz層的差別是什麼? 

首先解釋面上意思,service是業務層,dao是資料通路層。 

  呵呵,這個問題我曾經也有過,記得以前剛學程式設計的時候,都是在service裡直接調用dao,service裡面就new一個dao類對象,調用,其他有意義的事沒做,也不明白有這個有什麼用,參加工作久了以後就會知道,業務才是工作中的重中之重。 

  我們都知道,标準主流現在的程式設計方式都是采用MVC綜合設計模式,MVC本身不屬于設計模式的一種,它描述的是一種結構,最終目的達到解耦,解耦說的意思是你更改某一層代碼,不會影響我其他層代碼,如果你會像spring這樣的架構,你會了解面向接口程式設計,表示層調用控制層,控制層調用業務層,業務層調用資料通路層。初期也許都是new對象去調用下一層,比如你在業務層new一個DAO類的對象,調用DAO類方法通路資料庫,這樣寫是不對的,因為在業務層中是不應該含有具體對象,最多隻能有引用,如果有具體對象存在,就耦合了。當那個對象不存在,我還要修改業務的代碼,這不符合邏輯。好比主機闆上記憶體壞了,我換記憶體,沒必要連主機闆一起換。我不用知道記憶體是哪家生産,不用知道多大容量,隻要是記憶體都可以插上這個接口使用。這就是MVC的意義。 接下來說你感覺service的意義,其實因為你現在做東西分層次不是那麼嚴格,在一個你們做東西業務本身也少,舉個最簡單的例子,你做一個分頁的功能,資料1000條,你20條在一個頁,你可以把這個功能寫成工具類封裝起來,然後在業務層裡調用這個封裝的方法,這才是業務裡真正幹得事,隻要沒通路資料庫的,都要在業務裡寫。  

  再有不明白的追問,這是經驗問題,呵呵,其實以後你就會懂。隻是剛開始寫的代碼都是有個請求,我就去資料庫取,業務幾乎沒有。  

其他優秀答案: 

比說你現在用的是SSH架構,做一個使用者子產品: 

  (1)、假設現在你做這個功能會用到user表和權限表,那麼你前台的頁面通路action,action再去調用使用者子產品service,使用者子產品service判斷你是操作user表還是權限表,如果你操作的是user表則service的實作類就去調用userDAO。如果是操作的是權限表則調用權限的DAO 

  (2)、也就是說DAO一定是和資料庫的每張表一一對應,而service則不是。明白的沒?其實你一個項目一個service和一個DAO其實也一樣可以操作資料庫,

隻不過那要是表非常多,出問題了,那找起來多麻煩,而且太亂了 

 (3)、好處就是你的整個項目非常系統化,和資料庫的表能一緻,而且功能子產品化,這樣以後維護或者改錯比較容易,性能也高一些  

簡單的說DAO層是跟資料庫打交道的,service層是處理一些業務流程的,  

至于你說的為什麼要用service層封裝,我認為:一般來說,某一個程式的有些業務流程需要連接配接資料庫,有些不需要與資料庫打交道而直接是一些業務處理,這樣就需要我們整合起來到service中去,這樣可以起到一個更好的開發與維護的作用,同時也是MVC設計模式中model層功能的展現  

3.java中的action是什麼,DAO又是什麼? 

Action類 是[獲得Form表單資料,并處理邏輯的類]  

  DAO(Data Access Object) 是一個接口實作[通過SessionFactory獲得操作資料庫的會話,并實作一些基本的删除 添加 修改資料,在servlet中更實際化業務操作] 

4. 什麼是Pojo類? 

簡單的Java對象(Plain Old Java Objects)實際就是普通JavaBeans,使用POJO名稱是為了避免和EJB混淆起來, 而且簡稱比較直接. 其中有一些屬性及其getter setter方法的類,有時可以作為value object或dto(Data Transform Object)來使用.當然,如果你有一個簡單的運算屬性也是可以的,但不允許有業務方法,也不能攜帶有connection之類的方法。  

5.pojo類和vo類分别是什麼 

vo有兩種說法,一個是viewObject,一個是valueObject..

  就拿前者來說吧,它隻負責封裝頁面傳遞過來的資料,這和PO有些不同..

  就拿struts1來說,ActionForm就是一個典型的viewObject. 而valueObject是頁面與頁面之間的傳遞時儲存值的對象....

  總的來說,PO是最終傳給BO以及BO傳個DAO的東西,他很多情況下與我們真正的資料庫表想對應.

  而viewObject是一個頁面上送出後的資料,不一定完全和PO的屬性相同.... 

pojo與DTO的差別