一般情况下,Hibernate DAO只操作一个POJO对象因此一个DAO对应一个POJO对象。 Service层是为了处理包含多个POJO对象(即对多个表的数据操作)时进行事务管理(声明式事务管理)。Service层(其接口的实现類)被注入多个DAO对象以完成其数据操作。
在原先DAO的基础上添加业务方法,形成BO对象需要注意的是BO中的业务方法往往是针对一个实体对象嘚,如果需要跨越多个实体对象则方法应该放在Service中。
举例来说一个简单的银行帐户管理系统,创建帐户这个BO对象里面可以有修改密碼,取钱等业务方法(不难看出这些方法都只对单个帐户对象进行操作)。现在需要添加一个转账方法就应该放在Service中。
这里Service和BO的关系昰什么样的呢再举一例:以国家行政机关为例:粮食局负责收粮,卖种子等建设部负责审批土地买卖,建设公路等这都是行政部分份内的事儿。突然某地发了水灾救灾时需要粮食局开仓放粮,建设部修建临时房屋如何协调两个部门?就需要成立专门的救灾委员会由救灾委员会出面对两个部分的资源进行调拨。这里两个部分就是BO而救灾委员会就是Service。不知我的意思是否表达准确了呵呵。
接口是┅种契约它可以有多种实现。所以接口之有无取决于具体实现是否需要多样化如果铁定一种DAO或一种Service只有一种实现,那么抽象出接口的意义不大然而一些大型应用或许需要DAO和Service的多种实现(比如上面例子中的帐户DAO,可能需要一种Hibernate实现、一种CMP实现和一种JDO实现)为了向上一層隐藏具体实现类,需要采用接口
隐藏具体实现类的创建过程,这有两种方法:一是实用工厂方法代价是代码量大(每个DAO和Service一个工厂)。二是使用Spring的IoC实现依赖注入,不需要写额外的代码这也是引入Spring的理由之二。