• 编程珠玑:对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关系图如下:

        

  • 相关阅读:
    Android
    Android
    Android
    Android
    Android
    【工作中学习】CreateProcessAsUser失败,错误码:1314
    【Angular JS】网站使用社会化评论插件,以及过程中碰到的坑
    【Angular JS】正确调用JQuery与Angular JS脚本
    【工作】Proxy Server的优化
    AWS ELB Sticky Session有问题?别忘了AWSELB cookie
  • 原文地址:https://www.cnblogs.com/shihao/p/2415238.html
Copyright © 2020-2023  润新知