PO 就是对应数据库中某个表中的一条记录,PO 的属性是跟数据库表的字段一一对应的, 多个记录可以用 PO 的集合。 PO 中应该不包含任何对数据库的操作。PO 是有状态的,每个属性代表其当前的状态。它是物理数据的对象表示。使用它,可以使我们的程序与物理数据解耦,并且可以简化对象数据与物理数据之间的转换。PO 对象需要实现序列化接口。
PO 的生命周期: 是向数据库中添加新数据时创建,删除数据库中数据时削除的。并且它只能存活在一个数据库连接中,断开连接即被销毁。
eg: Hibernate 里的实体 bean 就是个 PO,也叫 POJO
就是从现实世界中抽象出来的有形或无形的业务实体
不同的应用程序之间传输的对象
这个概念来源于 J2EE 的设计模式, 原来的目的是为了 EJB 的分布式应用提供粗粒度的数据实体, 以减少分布式调用的次数, 从而提高分布式调用的性能和降低网络负载, 但在这里, 泛指用于展示层与服务层之间的数据传输对象。DTO 主要用于远程调用等需要大量传输对象的地方
通常用于业务层之间的数据传递, 和 PO 一样也是仅仅包含数据而已。 但应是抽象出的业务对象 , 可以和表对应 , 也可以不 , 这根据业务的需要 。 用 new 关键字创建, 由GC 回收的。
View object: 视图对象(表现层对象);
接受页面传递来的数据, 封装对象
将业务处理完成的对象, 封装成页面要用的数据
从业务模型的角度看 , 见 UML 元件领域模型中的领域对象。 封装业务逻辑的 java 对象 , 通过调用 DAO 方法 , 结合 PO,VO 进行业务操作。 business object: 业务对象 主要作用是把业务逻辑封装为一个对象。 这个对象可以包括一个或多个其它的对象。 比如一个简历, 有教育经历、 工作经历、 社会关系等等。 我们可以把教育经历对应一个 PO , 工作经历对应一个 PO , 社会关系对应一个 PO 。 建立一个对应简历的 BO 对象处理简历, 每个 BO 包含这些 PO 。 这样处理业务逻辑时, 我们就可以针对 BO 去处理。
传统意义的 java 对象。 就是说在一些 Object/Relation Mapping 工具中, 能够做到维护数据库表记录的 persisent object 完全是一个符合 Java Bean 规范的纯 Java 对象, 没有增加别的属性和方法。 我的理解就是最基本的 java Bean , 只有属性字段及 setter 和 getter方法!
POJO 是 DO/DTO/BO/VO 的统称。
一个 POJO 持久化以后就是 PO,直接用它传递、传递过程中就是 DTO,直接用来对应表示层就是 VO
是一个 sun 的一个标准 j2ee 设计模式, 这个模式中有个接口就是 DAO , 它负持久层的操作, 为业务层提供接口。 此对象用于访问数据库。 通常和 PO 结合使用, DAO 中包含了各种数据库的操作方法。 通过它的方法 , 结合 PO 对数据库进行相关的操作。 夹在业务逻辑与数据库资源中间。 配合 VO, 提供数据库的 CRUD 操作