实体类分层
VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对象。
DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。
PO(Persistent Object):持久化对象,它跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。
一、Why
上图是一个简单的应用场景。数据库中查出来的DO不能直接拿到前台显示。原因是:第一密码拿到前台不安全;第二性别是int型,前台不能直接显示数字;第三如果字段特别多,将不需要的信息也一次性传到前台数据里过大。
另外,后台业务在做数据处理的时候,如果gender直接用int型会带来类型不安全的问题,所以需要转换成DTO。由于前台大显示的大都是字符串或者数字类型,所以gender必须转换成String类型才能发送到前台(虽然DO直接传到前台也能处理,但是这种做法不优雅),所以DTO要转换成VO。整个过程反过来也是一样。
二、How
可以自己进行转换,但是会导致代码里全是getter和setter方法。可以使用现有的框架Dozer,配置一下就搞定。
R
https://cloud.tencent.com/developer/article/1129531