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 根据主键更新数据 表单修改、数据更新场景
相关推荐
java小白小1 小时前
Guava Cache 本地缓存
java
梦梦代码精1 小时前
LikeShop 二次开发扩展能力白皮书——面向业务增长的可扩展电商架构实践
java·架构·github
极客先躯1 小时前
高级java每日一道面试题-2025年12月05日-实战篇[Dockerj]-Docker 安装后的默认存储路径是什么?如何修改?
java·docker·默认存储路径在不同系统上的区别·linux overlay2·修改存储路径的理论方法·修改流程中的关键理论点
祁_z2 小时前
LangSmith 实操指南「Agent 可观测性系统」
java·服务器
小雅痞2 小时前
[Java][Leetcode hard] 76. 最小覆盖子串
java·算法·leetcode
MegaDataFlowers2 小时前
代码自动生成
java
dllxhcjla2 小时前
Spring全套
java·后端·spring
@杰克成2 小时前
Java学习24
java·学习·idea
挨踢ren2 小时前
C++虚函数:从基础到高阶
java·开发语言·jvm