目录

1、问题的背景

2、工程实践

3、总结


1、问题的背景

在写Java面向对象程序的过程中,我们往往不知不觉中写成了面向过程式的代码,特别是我们的Service服务对象是非常复杂,并且经常因为业务变更,我们代码一直在修改,很少关注程序中的扩展性。

2、工程实践

SpringBoot、Mybatis、Mysql技术架构背景来演示代码。本次实践,主要演示内容,将Service的职责进行分离,拆分为4个职责服务对象:增加、修改、查询、删除服务对象,然后将数据访问职责集成到DAO接口中,而DAO的实现,真正是委托给Manager层处理,而Manager则是需要委托Mapper来实现自己的职责。

package cn.vetech.center.cps.flsc.service.fc.common.service;import cn.hutool.core.clone.Cloneable;/** * CommonMsgService * 

遵守接口隔离原则,将原先的CommonMsgService一拆为三,CommonMsgUpdateService、CommonMsgQueryService、CommonMsgInsertService

* @author liqiao * @date 2021-12-24 09:46:27 */public interface CommonMsgService extends CommonMsgUpdateService, CommonMsgQueryService, CommonMsgInsertService, CommonMsgDeleteService, Cloneable { }

CommonMsgQueryServiceImpl源码,省略无关代码

/** * CommonMsgQueryService服务实现 * @author LiQiao * @date 2022/12/28 */@Slf4j@Primary@Servicepublic class CommonMsgQueryServiceImpl implements CommonMsgQueryService {    @Autowired    private ICommonMsgDao commonMsgDao;    @Autowired    private ICommonMsgRetryDao commonMsgRetryDao;}

CommonMsgDao源码,省略无关代码

/** * 基于DB的CommonMsg数据访问对象 * @author  liqiao * @date    2021-12-24 09:46:27 */@Componentpublic class CommonMsgDao implements ICommonMsgDao {    @Autowired    private CommonMsgManager commonMsgManager;    @Override    public List query(String application, String module, String scene, String busiId) {        return this.commonMsgManager.query(application, module, scene, busiId);    }}

CommonMsgManager源码,省略无关代码

/** * CommonMsgManager实现依赖于mybatis orm框架,对上层dao提供支持 * @author  liqiao * @date    2021-12-24 09:46:27 */@Componentpublic class CommonMsgManager extends BaseServiceImpl {    public List query(String application, String module, String scene, String busiId) {        EntityWrapper wrapper = new EntityWrapper();        wrapper.eq(CommonMsg.Column.APPLICATION, application);        wrapper.eq(CommonMsg.Column.MODULE, module);        wrapper.eq(CommonMsg.Column.SCENE, scene);        wrapper.eq(CommonMsg.Column.BUSI_ID, busiId);        List list = super.selectList(wrapper);        return list;    }}

3、总结

对于Service对象,我们一定要经常进行重构,至于什么时候应该重构,我们可见的现象是,
Service中方法数量是不是超过10个,一个方法代码行是不是超过80,类是不是快突破200行了,
这些都是一个信号,破坏了类的单一职责原则,这个时候,我们一定要将Service中的一个功能单元进行抽取,分离到其他Service对象中,进行职责分离;

第二,引入DAO层,目的在于解耦,因为数据访问层日后,可能进行变更,切换数据存储的实现,实现从Mysql切换为NoSql、ElasticSearch、NewSql等非RDBMS,Mybatis只是一个ORM框架,只解决关系型数据库的关系模型与对象模型的映射问题。并且,如果要将数据访问层单独部署,这个DAO层是非常有必要的。

第三,引入Mangager层,是将DAO层中涉及到多个表的CRUD操作进行组合; 
将事务下沉到Mangager层中,避免事务过长;Mangager对外部资源的访问进行转换与隔离

所以,我们总结,程序中DAO层是非常重要的,通常伴随着Manager层一起存在 。