java的(PO,VO,TO,BO,DAO,POJO)解釋java
action包 顧名思義請求,主要是和view 即咱們所說的視圖就是頁面打交道,action類 是 操做方法,對於頁 面Form 表單的操做方法,具體操做方法的實現就在Action 類裏面。
bean 就是基本的JavaBean ,多爲實體web
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方法組成。從結構上看,它們並無什麼不一樣的地方。但從其意義和本質上來看是徹底不一樣的。spring
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中應該不包含任何對數據庫的操做。app
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開發web應用時,須要對生成的各個類文件進行組織,下面就對一個可行的目錄方案進行介紹:
譬如應用中有一個用"戶管理模塊",則在公共包下創建一個"user"包,如該公共包能夠爲"com.simon.oa",
在user包下包括以下子包
一、controler包
該包放置各類struts的action。(執行調度功能)
二、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理解成一個可以進行實際操做的類,而不是一個接口,之後開發要注意)
三、model包
該包中放置hibernate反向工程生成的bean和該bean對應的.hbm.xml文件。
四、service包
該包放置業務操做類,譬如用戶服務類,通常狀況將該用戶操做類提取一個接口,而後在service包下生成一個impl包,在impl包中才放置用戶操做接口的實現類。該用戶接口實現類中調用DAO接口對數據庫進行操做,而調用該實現類的方法在struts的action中。
五、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屬性和一些其它的輔助方法,這也無可厚非,我本身也不能肯定這對不對。
實際的結構以下:
每一個項目拆分紅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