谈谈Controller、Service和Dao

都是Java代码,为啥要区分Controller、Service和Dao,谈谈我的理解。

当然,也可以不用区分,直接一条龙,从接受请求,到业务处理,再到数据库查询全写在一个类里,甚至全部在一个方法中完成,但是这样做,一是不利于代码的迭代,二是代码的结构不清晰。

当然,早期的代码其实就是这样。

总的来说,Controller 用于接收和响应;Service 用于处理业务逻辑,会调用DAO层的API;DAO是对应一张或多张表的,是持久层API,是针对单张或多张表的增删改查。

为了更方便理解,首先介绍Controller层,然后介绍Dao层,最后介绍Service层。

在Controller层定义的是请求和响应,是外部请求的入口和响应的出口,在这里,不应该出现业务逻辑的代码。

Dao层全称数据访问层,用于数据库的增删改查,当然,可以是一个数据库,也可以是多表联查,它表达的是对SQL语句的封装,是组成Service层的一部分。

Service层是业务逻辑层,在该层进行复杂的业务逻辑处理,对在多个Dao层查到的数据进行组装、处理,然后将结果返回给Controller,因此,一般情况下,一个Controller中可能包括多个Service,而一个Service中又或许包含多个Dao。

那么,这样设计的好处是什么?

目的就是为了解耦、提高代码整洁性,这两者的结果就是提高了代码的可维护性。

  • 8
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在典型的Java应用程序中,ControllerServiceDAO(Data Access Object)是三个关键组件,它们在应用程序中扮演不同的角色并协同工作。 1. Controller(控制器):Controller负责处理用户请求并将请求转发到适当的处理逻辑。它接收来自客户端的请求,并根据请求的类型和参数调用相应的Service方法来处理业务逻辑。Controller通常处理输入验证、参数传递和转发响应等任务。 2. Service(服务):Service层是应用程序的业务逻辑层,负责封装和实现具体的业务逻辑。Service层接收Controller传递的请求,并通过调用DAO层提供的方法来访问数据库或其他外部资源。它可以处理事务管理、数据转换、复杂的业务计算等任务。 3. DAO(数据访问对象):DAO层负责与数据库或其他数据存储机制进行交互,提供数据访问的接口和实现。它封装了对数据库的增删改查等基本操作,提供了对数据的持久化和检索功能。DAO层通常与特定的数据源(如关系型数据库)交互,并通过查询语言(如SQL)执行数据库操作。 在典型的应用程序中,Controller调用Service方法来处理业务逻辑,并且Service可以调用一个或多个DAO方法来访问数据库。这样的设计可以实现业务逻辑的封装和解耦,提高代码的可维护性和可测试性。同时,ControllerServiceDAO之间的关系也可以根据具体的应用需求进行调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值