关于DAO、Domain、Service三层
DAO层
Data Access Object
操作单表,不涉及复杂逻辑,主要是表的增删改查操作,完全根据Domain的要求来查询数据,会对每个要操作的数据库表定义一个Dao,对具体的操作要定义一个类似函数说明。
eg: UppCodeInfo findByCodeNo(String codeNo);JPA方式
Domain层
考虑业务逻辑,例如过滤条件,放行或者返回,以及数据的处理,为调用dao层做好准备,一个Domain可以调用一个或一组相关的Dao层.
eg:@Entity
@Table(name = "upp_code_info")
public class UppCodeInfo {属性....对应数据库表中的字段,要在后面生成set(),get()方法}
Service层
调用一个或一组Domain层,主要是展现需要开放出去的接口,其中domain层不是所有的接口都要再service层 体现的,可能仅在service层开放几个接口出去,此外,主要接口需要对接受的参数要尽量的扩大化,也就是说可以容纳各种类型的参数的接入 (Object),然后需要在service层做好转换,以备domain层使用。具体的逻辑实现在此层实现。即函数在该层实现。
controller层
作用在于过滤参数、和部分加解密和简单的逻辑处理 ,或者对于页面数据的封装,你可以理解为一个入口而service只需要处理复杂业务。
总结
底层数据库(具体数据的存储)→ DAO(从表中读取数据)→ Domain(将表与实体进行关联,进行实体的定义,set,get方法的定义) → service(实现逻辑,进行数据关联,方便底层取数据)→ controller(方便为前段提供数据)。
附:三层架构中的层
DAL:Data Access Layer
数据访问层,对原始数据(数据库或者文本文件等存放数据的形式)的操作层,而不是指原始数据,也就是说,是对数据的操作,而不是数据库,具体为业务逻辑层或表示层提供数据服务。
BLL:Business Logic Layer,也称作BIZ层
业务逻辑层,主要是针对具体的问题的操作,也可以理解成对数据层的操作,对数据业务逻辑处理。如果说数据层是积木,那逻辑层就是对这些积木的搭建。