您的位置:首页 > 其它

【转】VO BO PO 介绍

2016-04-15 12:07 134 查看
原文链接:http://www.cnblogs.com/zander/archive/2012/08/11/2633344.html

PO(persistant object)(个人理解:就是数据库模型 通过映射 转化成的 持久化类 model)

持久对象 在o/r映射的时候出现的概念,如果没有o/r映射,没有这个概念存在了。通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的java对象。最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何对数据库的操作。

VO(value object) 值对象 (个人理解:便于使用在po的基础上进行又一次加工而产生的对象)
通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要.个人觉得同DTO(数据传输对象),在web上传递。

BO(business object) 业务对象(个人理解:便于使用在vo的基础上进行 业务逻辑的 加工 后产生的类 service 层)
从业务模型的角度看,见UML元件领域模型中的领域对象。封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。

下边是我理解中的架构

--------------数据库

--------------model层
PO(persistant object)(个人理解:就是数据库模型 通过映射 转化成的 持久化类 model)
持久对象 在o/r映射的时候出现的概念,如果没有o/r映射,没有这个概念存在了。通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的java对象。最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何对数据库的操作。

VO(value object) 值对象 (个人理解:便于使用在po的基础上进行又一次加工而产生的对象)
通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要.个人觉得同DTO(数据传输对象),在web上传递。

--------------dao层

使用po vo对数据库进行的简单的操作 例如增删改查。。。。。

--------------service层
BO(business object) 业务对象(个人理解:便于使用在vo的基础上进行 业务逻辑的 加工 后产生的类 service 层) 从业务模型的角度看,见UML元件领域模型中的领域对象。封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。

-------------Controller层

利用service层的类进行实际的业务逻辑处理.

-------------View层
展示通过业务逻辑产生的一些列数据
============================================
这篇文章于我心有戚戚焉。
VO是查询结果,把前台需要的数据用对象封装起来,跟数据库表大不相同,比如要显示一个”帖子“,就要包含这个帖子相对应的话题题目,用户姓名,用户头像,用户学校等信息。


public class PostVo {
Long id;
Long createdTime;
String mediaPath;
String content;

TopicVo topic;

UserVo user;
Long authorId;
String authorName;
Long lastUserId;
String lastUserName;

Boolean hasForwarded;
Boolean hasPraised;
Integer commentCount;
Integer praiseCount;
Integer forwardCount;

Long forwardTime;
Long realTime;
}


PO是插入数据,当用户插入数据时,把传的参数封装成一个对象。因为上面userId在UserVo对象中取得,所以没法通过PostVo直接插入数据
而PO中的属性与数据库是一一对应的。


class TopicPo {
Long id;
Long createdTime;
Long userId;
String title;
String content;
Integer postCount;
String iconPath;
Integer form;
Integer fansCount;
}


除此之外,还有DTO数据传输对象,DO域对象,似乎他们并不是那么重要.
不要为了使用理论而使用理论,不要陷入特定的模式之中而固步自封,要一切从实际出发,去有选择地使用。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: