三层架构(Controller-Service-DAO)模式中的controller 和 dao/mapper的通俗理解

如果把 Web 应用比作一家餐厅,它们的分工如下:

1. Controller(控制器层):餐厅的"迎宾员/点餐员"

  • 职责 :它是程序的入口。Web 项目接收到的所有请求(如点击了一个按钮、提交了一个表单)都会首先到达这里。
  • 作用
    • 接收请求:解析用户传来的参数(比如 ID 是多少)。
    • 拦截与校验:检查参数是否合法。
    • 调度响应 :调用相应的 service 层来处理业务,拿到结果后,决定返回给用户什么样的界面或 JSON 数据。
  • 核心准则Controller 自己不要写业务逻辑! 它只负责"传话"和"分发"。

2. DAO/Mapper(数据访问层):餐厅的"库房管理员"

  • 名词解释DAOData Access Object 的缩写;在 MyBatis 等框架中,习惯叫 Mapper
  • 职责 :它是代码与数据库之间的直接沟通桥梁。
  • 作用
    • 执行 SQL:增、删、改、查(CRUD)。
    • 屏蔽底层service 层不需要知道数据库是用 MySQL 还是 Oracle,也不需要写复杂的 SQL 语句,只需要调用 mapper.selectById(id) 这样的简单方法。
  • 核心准则Mapper 只做一件事------把对象存入数据库,或从数据库取出对象。

它们是如何协作的?(以"查询用户信息"为例)

当你访问一个"查询用户详情"的网页时,数据流向是这样的:

  1. 用户 :点击链接 http://api.myapp.com/user/1
  2. Controller :接收到请求,解析出 ID 为 1。对 service 说:"帮我查一下 ID 为 1 的用户。"
  3. Service :调用 mapper 说:"根据 ID 给我在数据库里捞出这个用户的数据。"
  4. DAO/Mapper :执行 SQL SELECT * FROM user WHERE id = 1,将结果包装成一个 User 对象(domain 类)返回给 service
  5. Service :可能还会对这个对象做一些业务判断(比如该用户是否被封禁),然后传回给 controller
  6. Controller:把拿到的对象转成 JSON 返回给浏览器。

为什么这样做?

这种分层开发有三个巨大的优势:

  • 分而治之 :当你觉得查询速度慢时,你肯定去优化 mapper(SQL 语句);当你觉得业务规则改了,去优化 service;当你觉得网页接口地址改了,去优化 controller你不需要去改动不相关的代码。
  • 解耦 :如果以后数据库要从 MySQL 换成 MongoDB,你只需要修改 mapper 实现,controllerservice 的代码完全不需要动。
  • 多人协作:一个人写界面和 Controller(前端向),一个人写业务逻辑(Service),一个人写复杂的 SQL 操作(DBA/后端)。大家各司其职,互不干扰。

总结:

  • Controller:指挥官(接收请求)。
  • Service:大脑(处理逻辑)。
  • Domain:数据模板(定义对象)。
  • DAO/Mapper:搬运工(跟数据库打交道)。
  • Util:工具箱(提供方便的辅助工具)。

这套结构是 Java 领域最流行的"标准模板"。理解了它们,你就掌握了后端开发的核心流程!

相关推荐
真实的菜1 小时前
Nacos单机部署入门:避坑指南与实战
java
霸道流氓气质1 小时前
JWT 认证全面解析:原理、流程与 Spring Boot 实战
java·spring boot·后端
TeamDev1 小时前
JxBrowser 9.1.2 版本发布啦!
java·跨平台·混合应用·jxbrowser·浏览器控件·compose 多平台
逢君学术论文AI写作2 小时前
Java第21课:JavaWeb入门——Tomcat+第一个Servlet
java·servlet·tomcat
就叫_这个吧2 小时前
Java使用tomcat+servlet+filter实现简单的登录功能,需先登录再进行页面数据管理操作
java·开发语言·servlet·tomcat·jsp·filter
十五年专注C++开发2 小时前
ANTLR4: CORBA IDL、C++ 语法文件分析利器
java·开发语言·c++·antlr4
子非衣2 小时前
Java使用Aspose进行Word转PDF时异常卡主问题
java·pdf·word
此生决int2 小时前
Java面向对象进阶精讲:抽象类、接口、内部类与Object类万字详解
java