java的(PO,VO,TO,BO,DAO,POJO)類名包名解釋


java的(PO,VO,TO,BO,DAO,POJO)解釋


action包  顧名思義請求,主要是和view 即我們所說的視圖就是頁面打交道,action類 是 操作方法,對於頁 面Form 表單的操作方法,具體操作方法的實現就在Action 類里面。
bean 就是基本的JavaBean ,多為實體

dao包 就是和數據庫打交道的,crud 即增刪改查,對於數據庫的增刪改查的操作都在這里。
model 就是實體類,就是和數據庫對於,所生產表的一些屬性
service 服務器層,也叫業務邏輯層,調用dao中的方法,action又調用它

DTO = Data Transfer Object
VO = Value Object
2個概念其實是一個感念,都是用來裝數據用的,而這個數據往往跟數據庫沒什么關系

util 即工具類,放常用到的工具方法 

O/R Mapping 是 Object Relational Mapping(對象關系映射)的縮寫。通俗點講,就是將對象與關系數據庫綁定,用對象來表示關系數據。在O/R Mapping的世界里,有兩個基本的也是重要的東東需要了解,即VO,PO。
  VO,值對象(Value Object),PO,持久對象(Persisent Object),它們是由一組屬性和屬性的get和set方法組成。從結構上看,它們並沒有什么不同的地方。但從其意義和本質上來看是完全不同的。

1.VO是用new關鍵字創建,由GC回收的。
  PO則是向數據庫中添加新數據時創建,刪除數據庫中數據時削除的。並且它只能存活在一個數據庫連接中,斷開連接即被銷毀。

2.VO是值對象,精確點講它是業務對象,是存活在業務層的,是業務邏輯使用的,它存活的目的就是為數據提供一個生存的地方。
  PO則是有狀態的,每個屬性代表其當前的狀態。它是物理數據的對象表示。使用它,可以使我們的程序與物理數據解耦,並且可以簡化對象數據與物理數據之間的轉換。

3.VO的屬性是根據當前業務的不同而不同的,也就是說,它的每一個屬性都一一對應當前業務邏輯所需要的數據的名稱。
  PO的屬性是跟數據庫表的字段一一對應的。

PO對象需要實現序列化接口。
-------------------------------------------------

PO是持久化對象,它只是將物理數據實體的一種對象表示,為什么需要它?因為它可以簡化我們對於物理實體的了解和耦合,簡單地講,可以簡化對象的數據轉換為物理數據的編程。VO是什么?它是值對象,准確地講,它是業務對象,是生活在業務層的,是業務邏輯需要了解,需要使用的,再簡單地講,它是概念模型轉換得到的。
首先說PO和VO吧,它們的關系應該是相互獨立的,一個VO可以只是PO的部分,也可以是多個PO構成,同樣也可以等同於一個PO(當然我是指他們的屬性)。正因為這樣,PO獨立出來,數據持久層也就獨立出來了,它不會受到任何業務的干涉。又正因為這樣,業務邏輯層也獨立開來,它不會受到數據持久層的影響,業務層關心的只是業務邏輯的處理,至於怎么存怎么讀交給別人吧!不過,另外一點,如果我們沒有使用數據持久層,或者說沒有使用hibernate,那么PO和VO也可以是同一個東西,雖然這並不好。


----------------------------------------------------
java的(PO,VO,TO,BO,DAO,POJO)解釋

PO(persistant object) 持久對象
在o/r映射的時候出現的概念,如果沒有o/r映射,沒有這個概念存在了。通常對應數據模型(數據庫),本身還有部分業務邏輯的處理。可以看成是與數據庫中的表相映射的java對象。最簡單的PO就是對應數據庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對數據庫的操作。

VO(value object) 值對象
通常用於業務層之間的數據傳遞,和PO一樣也是僅僅包含數據而已。但應是抽象出的業務對象,可以和表對應,也可以不,這根據業務的需要.個人覺得同DTO(數據傳輸對象),在web上傳遞。

TO(Transfer Object),數據傳輸對象
在應用程序不同tie(關系)之間傳輸的對象

BO(business object) 業務對象
從業務模型的角度看,見UML元件領域模型中的領域對象。封裝業務邏輯的java對象,通過調用DAO方法,結合PO,VO進行業務操作。

POJO(plain ordinary java object) 簡單無規則java對象
純的傳統意義的java對象。就是說在一些Object/Relation Mapping工具中,能夠做到維護數據庫表記錄的persisent object完全是一個符合Java Bean規范的純Java對象,沒有增加別的屬性和方法。我的理解就是最基本的Java Bean,只有屬性字段及setter和getter方法!。

DAO(data access object) 數據訪問對象
是一個sun的一個標准j2ee設計模式,這個模式中有個接口就是DAO,它負持久層的操作。為業務層提供接口。此對象用於訪問數據庫。通常和PO結合使用,DAO中包含了各種數據庫的操作方法。通過它的方法,結合PO對數據庫進行相關的操作。夾在業務邏輯與數據庫資源中間。配合VO, 提供數據庫的CRUD操作...

O/R Mapper 對象/關系 映射
定義好所有的mapping之后,這個O/R Mapper可以幫我們做很多的工作。通過這些mappings,這個O/R Mapper可以生成所有的關於對象保存,刪除,讀取的SQL語句,我們不再需要寫那么多行的DAL代碼了。

實體Model(實體模式)
DAL(數據訪問層)
IDAL(接口層)
DALFactory(類工廠)
BLL(業務邏輯層)
BOF Business Object Framework 業務對象框架
SOA Service Orient Architecture 面向服務的設計
EMF Eclipse Model Framework Eclipse建模框架

----------------------------------------

PO:全稱是
persistant object持久對象
最形象的理解就是一個PO就是數據庫中的一條記錄。
好處是可以把一條記錄作為一個對象處理,可以方便的轉為其它對象。

BO:全稱是
business object:業務對象
主要作用是把業務邏輯封裝為一個對象。這個對象可以包括一個或多個其它的對象。
比如一個簡歷,有教育經歷、工作經歷、社會關系等等。
我們可以把教育經歷對應一個PO,工作經歷對應一個PO,社會關系對應一個PO。
建立一個對應簡歷的BO對象處理簡歷,每個BO包含這些PO。
這樣處理業務邏輯時,我們就可以針對BO去處理。

VO :
value object值對象
ViewObject表現層對象
主要對應界面顯示的數據對象。對於一個WEB頁面,或者SWT、SWING的一個界面,用一個VO對象對應整個界面的值。

DTO :
Data Transfer Object數據傳輸對象
主要用於遠程調用等需要大量傳輸對象的地方。
比如我們一張表有100個字段,那么對應的PO就有100個屬性。
但是我們界面上只要顯示10個字段,
客戶端用WEB service來獲取數據,沒有必要把整個PO對象傳遞到客戶端,
這時我們就可以用只有這10個屬性的DTO來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端以后,如果用這個對象來對應界面顯示,那此時它的身份就轉為VO

POJO :
plain ordinary java object 簡單java對象
個人感覺POJO是最常見最多變的對象,是一個中間對象,也是我們最常打交道的對象。

一個POJO持久化以后就是PO
直接用它傳遞、傳遞過程中就是DTO
直接用來對應表示層就是VO

DAO:
data access object數據訪問對象
這個大家最熟悉,和上面幾個O區別最大,基本沒有互相轉化的可能性和必要.
主要用來封裝對數據庫的訪問。通過它可以把POJO持久化為PO,用PO組裝出來VO、DTO

-----------------------------------------------------------------

PO:persistant object持久對象,可以看成是與數據庫中的表相映射的java對象。最簡單的PO就是對應數據庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對數據庫的操作.

VO:value object值對象。通常用於業務層之間的數據傳遞,和PO一樣也是僅僅包含數據而已。但應是抽象出的業務對象,可以和表對應,也可以不,這根據業務的需要.個人覺得同DTO(數據傳輸對象),在web上傳遞.


DAO:data access object數據訪問對象,此對象用於訪問數據庫。通常和PO結合使用,DAO中包含了各種數據庫的操作方法。通過它的方法,結合PO對數據庫進行相關的操作.


BO:business object業務對象,封裝業務邏輯的java對象,通過調用DAO方法,結合PO,VO進行業務操作;


POJO:plain ordinary java object 簡單無規則java對象,我個人覺得它和其他不是一個層面上的東西,VO和PO應該都屬於它.


---------------------------------------------
VO:值對象、視圖對象
PO:持久對象
QO:查詢對象
DAO:數據訪問對象
DTO:數據傳輸對象
----------------------------------------
struts 里的 ActionForm 就是個VO;
hibernate里的 實體bean就是個PO,也叫POJO;
hibernate里的Criteria 就相當於一個QO;
在使用hibernate的時候我們會定義一些查詢的方法,這些方法寫在接口里,可以有不同的實現類.而這個接口就可以說是個DAO.
個人認為QO和DTO差不多.
----------------------------------------
PO或叫BO,與數據庫最接近的一層,是ORM中的O,基本上是數據庫字段對應BO中的一個屬性,為了同步與安全性考慮,最好只給DAO或者Service調用,而不要用packcode,backingBean,或者BO調。
DAO,數據訪問層,把VO,backingBean中的對象可以放入。。。。
DTO,很少用,基本放入到DAO中,只是起到過渡的作用。
QO,是把一些與持久性查詢操作與語句放入。。
VO,V層中用到的基本元素與方法等放其中。如果要其調用BO,則要做BO轉換VO,VO轉換BO操作。VO的好處是其頁面的元素屬性多於BO,可起到很好的作用。。。。
-----------------------------------------
樓上的不對吧,PO是持久化對象。BO=business object—業務對象。
PO可以嚴格對應數據庫表,一張表對映一個PO。
BO則是業務邏輯處理對象,我的理解是它裝滿了業務邏輯的處理,在業務邏輯復雜的應用中有用。
VO:value object值對象、view object視圖對象
PO:持久對象
QO:查詢對象
DAO:數據訪問對象——同時還有DAO模式
DTO:數據傳輸對象——同時還有DTO模式

 

SSH開發目錄結構設置(轉)

在用ssh開發web應用時,需要對生成的各個類文件進行組織,下面就對一個可行的目錄方案進行介紹:

譬如應用中有一個用"戶管理模塊",則在公共包下建立一個"user"包,如該公共包可以為"com.simon.oa",

在user包下包括如下子包

1、controler包

該包放置各種struts的action。(執行調度功能)

2、dao包

該包放置各類dao(data access object),也就是放置對數據庫訪問的實現類,在用myeclipse中的“Hibernate Reverse Engineering”進行反向操作時在某一個目錄中就會生成對應某個表的DAO,生成后可將該DAO拖到dao包中。在某些應用中將DAO作為接口,在該接口中包括所有對數據庫的操作方法,然后在dao包建立一個hibernate包,在hibernate包中放置對DAO接口的實現,譬如:UserDAO接口有一個實現類為UserDaoImpl,將該類放置到hibernate包中,實際的開發傾向於后一種方式,因為對這個DAO接口可以實現spring的IoC操作。(不知道myeclipse對此是怎么考慮的,這個問題讓我糾纏了很久,誤將DAO理解成一個能夠進行實際操作的類,而不是一個接口,以后開發要注意)

3、model包

該包中放置hibernate反向工程生成的bean和該bean對應的.hbm.xml文件。

4、service包

該包放置業務操作類,譬如用戶服務類,一般情況將該用戶操作類提取一個接口,然后在service包下生成一個impl包,在impl包中才放置用戶操作接口的實現類。該用戶接口實現類中調用DAO接口對數據庫進行操作,而調用該實現類的方法在struts的action中。

5、vo包(value object)

vo包中的中包括struts中使用的POJO及actionform等信息。所有的ActionForm都被配置在struts-config.xml文件中,該文件包括了一個form-beans的元素,該元素內定義了所有ActionForm,每個ActionForm對應一個form-bean元素。

VO: Value Object
DTO: Data Transfer Object
個人理解VO和DTO是類似的東西,原則上VO和DTO只有Public Fields,主要用於進程之間數據傳遞的問題,VO和DTO不會傳遞到表示層,在業務層就會被吸收。但看到很多人在建立VO和DTO時,也含有Setter,Getter屬性和一些其它的輔助方法,這也無可厚非,我自己也不能確定這對不對。

實際的結構如下:

java的(PO,VO,TO,BO,DAO,POJO)類名包名解釋

每個項目拆分成model、dao、service(含命令行)、util(工具類和靜態常量)、userapp、admapp等6個子模塊兒,每個子模塊兒為一個獨立項目,使用eclipse的workset組裝成層級項目;對應到svn版本庫的trunk下細分成project-model、project-dao、project-service、project-util、project-userapp、project-admapp。

vo主要是用於傳遞數據的相當於dto,數據的載體對象
po主要是和你數據庫表一一對應的,主要作用與dao層
po向vo轉變主要發生在service,在由你的controller層
調用service返回的vo 傳遞到頁面進行展示,這里提示一點
po轉vo不是決定的,一般是多變查詢的數據設計到兩個表的數據的時候
會涉及到vo,還有你在寫webservice傳遞對象的時候 會涉及到vo


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM