场景:订单系统
订单有自己的一套实体,OrderDO里面有orderId,orderPrice......
订单还和另外一个系统有关联,当生成一个订单的时候,同时也需要生成和对应系统的关系(一个orderId对应一条记录)RelativeDO,并且存储相应的data数据。
需求
现在需要提供一个接口,接口接受一个OrderId,订单系统返回给他一个数据结构。数据结构中需要有订单的信息和关系的一些信息(比如存储的data数据)
按照需求抽象出一个DTO用来承载数据,但是这个时候把订单的一些信息和存储的信息放在一个实体里面总觉得怪怪的。因为这几个字段根本没有关联呀。
本来想通过组合的方式来将OrderDO和RelativeDO用组合的方式生成一个DTO并提供相应的接口。但是因为OrderDO自身的一些原因(OrderDO里面的数据结构很乱,这样做的话,每次取数据都需要对OrderDO进行深层次的遍历才能取到值,这样子没获取一个订单数据都要遍历一遍,效率很低)不能这么做。
但是跳出来想一下,这个DTO本来就是用来承载数据的一个抽象,所以就算里面有这些不相关的属性也没有关系。
该怎么解释这种现象,或者怎么去抽象这个场景下的DTO?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。