使用SpringBoot+MyBatis+MySQL完成后端的数据库增删改查(CRUD)操作

文章目录


执行流程

前端/Postman发请求 → Controller接收请求 → Service处理业务 → Dao访问数据库 → MyBatis的XML执行SQL → 返回结果
Controller 接请求,Service 处理业务,Dao 调 SQL,XML 操作数据库,Entity 封装数据。

每一层到底负责什么?

Entity层

Dao层(包含两个文件)


Service层(包含两个文件)

Service 是业务层,主要负责:

复制代码
调用 Dao
处理业务逻辑
决定返回什么结果



Controller层

Controller 负责接收 HTTP 请求。

每一层在 CRUD 中是怎么协作的

我们拿"查询 id=1 的用户"为例。

第一步:Postman 发请求

第二步:Controller 接收

第三步:Service 调用 Dao

第四步:Dao 找到 XML 中同名 SQL

第五步:返回 JSON 给前端/Postman

CRUD各接口到底该怎么用?

查询单个用户

查出 mall_user 表里 id=1 的数据。

复制代码
http://localhost:8080/mallUser/1


新增用户

复制代码
http://localhost:8080/mallUser


修改用户

修改 id=1 的这条记录,把用户名改成"李四",地址改成"shanghai"。

复制代码
http://localhost:8080/mallUser


删除用户

复制代码
http://localhost:8080/mallUser?id=1


CRUD的本质

补一个"查询所有用户"接口

Dao

java 复制代码
List<MallUser> queryAll();

XML

xml 复制代码
<select id="queryAll" resultMap="MallUserMap">
    select id, user_id, user_name, user_gender, user_address, user_birthday, user_phone, create_time, update_time
    from mall_user
</select>

Service

java 复制代码
List<MallUser> queryAll();

ServiceImpl

java 复制代码
@Override
public List<MallUser> queryAll() {
    return this.mallUserDao.queryAll();
}

Controller

java 复制代码
@GetMapping
public ResponseEntity<List<MallUser>> queryAll() {
    return ResponseEntity.ok(this.mallUserService.queryAll());
}

测试

复制代码
http://localhost:8080/mallUser
相关推荐
Devin~Y19 小时前
大厂Java面试实战:Spring Boot/Cloud、Redis/Kafka、JVM调优与Spring AI RAG(内容社区UGC+AIGC客服场景)
java·jvm·spring boot·redis·spring cloud·kafka·mybatis
前进的李工19 小时前
高效索引优化:数据库查询提速指南(适合创建索引的11种情况)
数据库·mysql·面试
l1t19 小时前
DeepSeek总结的无需编译器:编写纯 SQL 的 Postgres 扩展
数据库·sql·postgresql
【心态好不摆烂】19 小时前
MySQL数据类型
数据库·mysql
码云骑士20 小时前
jwt入门介绍
linux·运维·数据库
努力努力再努力wz20 小时前
【Redis 入门系列】为什么需要 Redis?一文串起缓存、分布式、读写分离、分库分表与微服务
数据库·redis·分布式·sql·mysql·缓存·微服务
得闲喝茶20 小时前
SQL处理数据的常用语法语句
数据库·笔记·sql·数据分析·excel
金玉满堂@bj20 小时前
PostgreSQL:企业级全能开源数据库
数据库·postgresql·开源
秋920 小时前
springboot项目中使用mysql8.0.46版本,具体如何配置及常见问题解决方法
spring boot·mysql8.0.46
todoitbo20 小时前
CTE 与外层 JOIN 的条件下推:原理、边界与验证方法
数据库·join·cte