使用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
相关推荐
程序员晓琪3 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly3 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
倔强的石头_12 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3521802454751 天前
🎆从 Prompt 到 Skill:让 Spring AI Agent 学会"装新技能"
人工智能·spring boot·ai编程
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
用户3521802454754 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
昵称为空C4 天前
手撸一个动态 SQL 执行引擎:不重启服务,在线增删改查任意数据库
spring boot·后端
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神4 天前
三、用户与权限管理
数据库·mysql