使用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
相关推荐
oradh2 小时前
Oracle数据库视图概述
数据库·oracle·数据库视图·oracle基础·oracle入门
a9511416422 小时前
Python字典底层实现_dict哈希结构解析
jvm·数据库·python
做个文艺程序员2 小时前
Spring Boot 封装 OpenClAW 服务层最佳实践【OpenClAW + Spring Boot 系列 第2篇】
java·人工智能·spring boot·开源
LiAo_1996_Y2 小时前
MongoDB中什么是Hashed Shard Key的哈希冲突_哈希函数的分布均匀性分析
jvm·数据库·python
weixin_381288182 小时前
PyTorch中高效实现SOM邻域权重更新:向量化替代双重循环
jvm·数据库·python
m0_617881422 小时前
在 Go 中声明包级全局 Map 的正确方法
jvm·数据库·python
Polar__Star2 小时前
Redis怎样管理废弃的数据集合_利用EXPIRE指令为任意数据类型设置生命周期
jvm·数据库·python
weixin_568996062 小时前
CSS布局如何解决父级因全是绝对定位导致本身没高度的问题
jvm·数据库·python
2601_949816682 小时前
如何在 Spring Boot 中配置数据库?
数据库·spring boot·后端