编程珠玑:对DAO层的一点修改

    由于以前的Domain对象都是不需要序列化的,所以为了操作数据库查询的方便,直接采用继承BaseDomain的方式来完成。这样在传递动态参数的时候,只需要把参数放到Map总,就可以很好的在ibatis配置文件(map.xx来直接获取值)中使用。

    这样导致的一个害处就是对象看起来有直接根本就不需要的属性,即使你添加关键字transient,不少程序员依然在set的时候会费解一些不必要的属 性。例如:在insert()设置属性的时候竟然能够setPageNo()。质疑这个很有道理,但是以前一直extends粗暴简单的来完成任务,没有 额外的系统设计问题,所以就得过且过,没有继续抽象。

    目前,Domain对象需要额外提供序列化的功能和为API服务,简单粗暴的方式不能继续适应系统要求,所以需要继续抽象。在CRUD的模型中,逐个分析需求变化导致的问题。

  1.     insert() , update() , delete() 都可以直接传入对象,不需要额外的值,即使有这样的条件,也建议不动态传值到ibatis中;
  2.     find() , list() 需要动态出入参数,同事find和list传入的参数值有所不同;list和find参数存在继承关系;

    按照需求,设计抽象有3点:

  •     FindAapter() 提供动态参数的设置;
  •     ListAaapter() 提供分页的参数的设置,继承FindAapter()  接口;
  •     用泛型动态传递Domain对象,让相关返回规范化。

    UML关系图如下:

    

原文地址:https://www.cnblogs.com/shihao/p/2415238.html