【OA】Dao层“接口”、“实现”两个维度一个良好的设计学习

来源:互联网 发布:北京优化 编辑:程序博客网 时间:2024/05/17 03:32

    在学习OA系统的时候,鉴于已经搭建起来的SSH框架,首先要做的就是从底层开始做起,结合所做的项目更多的是在前人基础上修改,这次学习如何设计Dao也是让我大开眼界,总结成博客,便于以后再回头学习。

    一、包设计

    项目名称:ItcastOA

    资源文件夹:src、config、test

     

       由于“src”用于存放主代码,对DAO的接口、实现就该放到这里,主要的package如图:

              

         预先设计“cn.itcast.oa.dao”存放dao层的接口,“cn.itcast.oa.dao.impl”存放dao层接口的实现,“cn.itcast.oa.base”存放公共的抽象出来的接口(这里应该有一个"cn.itcast.oa.base.impl"包,用于存放对base接口的实现)。

     

   二、接口设计

    1、dao层用于和数据库交互,执行增删改查操作,务必会用到"save();update();get();delete();"这些方法,不同的模块、业务,会有不同的dao以及daoimpl,但是对于上面几个方法就会大量重复,很明显在dao层,最为公用的这几个方法需要抽象出来。

    2、由于dao层中的接口与方法是成对出现的,如果要抽象接口,是不是一定要抽象实现呢?

      

   三、创建类

    假定目前有“User”、“Role”、两个模块

    (1)在cn.itcast.oa.base包下,新建BaseDao.java类,在test这个source folder下的cn.itcast.oa.base下新建BaseDaoTest.java类。

    (2)在cn.itcast.oa.dao下,写两个interface,RoleDao以及UserDao;

    (3)在cn.itcast.oa.dao.impl下面,写两个实现类,RoleDaoImpl.java以及UserDaoImpl.java,这里分别实现RoleDao的接口以及UserDao的接口。

      

   四、实现思路

   (1)接口设计

       

        1、接口继承接口,用公共的接口来写公共的方法,对于save(entity: T)方法,使用<T>泛型传入参数,对于getById(id:Long),传入一个id,返回值为T,对于getByIds(ids:Long[]),传入数组,返回List<T>,通过使用泛型<T>,解决了传入类型以及返回值类型不同步的问题。

    2、特定模块的接口,类似(UserDao)中可以写自己独有的接口方法。

  (2)实现思路

       

        (1)由于每个实现类“UserDaoImpl”以及“RoleDaoImpl”分别都要实现对应的接口,即BaseDao中的接口方法需要在每个实现类中实现,冗余了,这个时候,提取出了一个公共的实现类,BaseDaoImpl,如图所示,将BaseDao<T>中的方法,从save()到findAll()都予以实现,让具体模块的实现类类似UserDaoImpl以及RoleDao分别继承BaseDaoImpl,此时,在特定的模块实现类中,仅仅需要实现自己特定接口中的方法,比如UserDaoImpl仅仅需要实现findByName()方法就好了。


   小结:

    1、粒度的把控,项目设计过程中,如果类似Dao这样的设计,哪些需要放到BaseDao中,值得思考。

    2、泛型传递,从UserDaoImpl到BaseDaoImpl到BaseDao,将泛型<T>向上传递了2层。


        

0 0