spring boot--04

一、新增操作(基础版)

1. 场景说明

新增员工数据,对应前端 "新增员工" 表单。

2. SQL 语句

sql

复制代码
insert into emp(username, name, gender, image, job, entrydate, dept_id, create_time, update_time)
values ('songyuanqiao','宋远桥',1,'1.jpg',2,'2012-10-09',2,'2022-10-01 10:00:00','2022-10-01 10:00:00');

3. Mapper 接口方法

java

运行

复制代码
@Insert("insert into emp(username, name, gender, image, job, entrydate, dept_id, create_time, update_time) " +
        "values(#{username}, #{name}, #{gender}, #{image}, #{job}, #{entrydate}, #{deptId}, #{createTime}, #{updateTime})")
public void insert(Emp emp);

二、新增操作(主键返回版)

1. 场景说明

新增数据后需要获取数据库自动生成的主键,例如:

  • 新增套餐时,需要先保存套餐信息,获取套餐ID,再维护套餐与菜品的关联关系表。

2. 实现方式

通过@Options注解开启主键返回:

java

运行

复制代码
// keyProperty: 实体类中接收主键的属性名;useGeneratedKeys: 开启获取自增主键
@Options(keyProperty = "id", useGeneratedKeys = true)
@Insert("insert into emp(username, name, gender, image, job, entrydate, dept_id, create_time, update_time) " +
        "values(#{username}, #{name}, #{gender}, #{image}, #{job}, #{entrydate}, #{deptId}, #{createTime}, #{updateTime})")
public void insert(Emp emp);

3. 效果

调用insert方法后,传入的emp对象的id属性会被自动赋值为数据库生成的主键值,后续可直接使用该id进行关联操作。


三、更新操作(根据 ID 更新)

1. 场景说明

修改员工信息,对应前端 "修改员工" 表单,根据主键id更新数据。

2. SQL 语句

sql

复制代码
update emp set username = 'songdaxia', name = '宋大侠', gender = 1, image = '1.jpg', job = 2, entrydate = '2012-01-01', dept_id = 2, update_time = '2022-10-01 12:12:12' where id = 19;

3. Mapper 接口方法

java

运行

复制代码
@Update("update emp set username=#{username}, name=#{name}, gender=#{gender}, image=#{image}, job=#{job}, " +
        "entrydate=#{entrydate}, dept_id=#{deptId}, update_time=#{updateTime} where id=#{id}")
public void update(Emp emp);

四、核心知识点总结

表格

操作 关键注解 核心作用 适用场景
基础新增 @Insert 插入数据 无需后续关联操作的简单新增
带主键返回新增 @Insert + @Options 插入数据并获取自增主键 新增主表数据后,需维护关联表数据
更新 @Update 根据主键更新数据 表单修改、数据更新场景
相关推荐
ps酷教程1 小时前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云2 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
_日拱一卒3 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠3 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨3 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝3 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区4 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
金銀銅鐵4 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
云烟成雨TD4 小时前
Spring AI Alibaba 1.x 系列【63】AI Agent 长期记忆
java·人工智能·spring
憧憬成为java架构高手的小白4 小时前
苍穹外卖--day09
java·spring boot·百度