SQL主键回显

目录

[一 业务场景](#一 业务场景)

[二 如何使用](#二 如何使用)


一 业务场景

当我们在一个业务功能下操作多张表时,当另一个表数据需要上一个表刚插入的数据的ID时,就需要使用到主键回显。

比如我现在有两张表,一张是菜品表,一张是口味表。而我一个菜品应该会有多个口味,所以当我们在实现菜品插入功能的时候,我们还需要在插入完成菜品后,再把该菜品的口味也插入到对应的口味表中,而口味表中当然就需要所属菜品的id了。

那么现在的问题就是,在菜品还没有插入之前,我是不知道菜品id的,因为菜品id是在菜品插入之后生成的id,所以我就需要在菜品插入完成后,再获得这个菜品生成的id赋值给口味对象,那么就需要使用到主键回显功能。

二 如何使用

其实使用起来很简单,本次记录只是加深自己的印象或者下次忘记了可以方便自己来这里寻找。

首先执行完菜品的插入功能:

java 复制代码
dishMapper.addDish(dish);

然后,我们需要获取到插入成功后,生成的菜品对象的id:

java 复制代码
 Long dishId = dish.getId();

当然,像上面这样直接取是拿不到的,因为dish对象才new出来的时候,它的id就是null,只是因为在执行sql插入语句的时候,才生成的id直接插入到数据库表中。所以我们需要在执行插入菜品的sql语句中配置属性来获取到生成的id:

XML 复制代码
 <insert id="addDish" parameterType="com.sky.entity.Dish" useGeneratedKeys="true" keyProperty="id">
        insert into dish (id, name, category_id, price, image, description, status, create_time, update_time, create_user, update_user) values
                         (#{id},#{name},#{categoryId},#{price},#{image},#{description},#{status},#{createTime},#{updateTime},#{createUser},#{updateUser})
    </insert>

如上,只需要配置:useGeneratedKeys="true" keyProperty="id"这两个属性即可,第一个表示开启主键回显,第二个表示回显到dish对象的id属性上面,所以这个id不能乱写,要和你对象的主键id属性名一样。

这样配置后,就可以使用刚刚上面的get方法获取到id值啦!然后就可以按照需要赋值给你所需要的对象属性中去啦!

相关推荐
我真的是大笨蛋21 分钟前
Redo Log详解
java·数据库·sql·mysql·性能优化
fengxin_rou36 分钟前
Redis 从零到精通:第一篇 初识redis
数据库·redis·缓存
爱学习的阿磊42 分钟前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
m0_736919101 小时前
Python面向对象编程(OOP)终极指南
jvm·数据库·python
OceanBase数据库官方博客1 小时前
滔搏基于OceanBase实现 15TB到0.9TB“无痛切换”与“系统瘦身”
数据库·oceanbase·分布式数据库
Jess071 小时前
MySQL内置函数
数据库·mysql
OceanBase数据库官方博客1 小时前
爱奇艺基于OceanBase实现百亿级卡券业务的“单库双擎”架构升级
数据库·架构·oceanbase·分布式数据库
weixin199701080161 小时前
锦程物流item_get - 获取详情接口对接全攻略:从入门到精通
数据库·python
AC赳赳老秦1 小时前
DeepSeek 辅助科研项目申报:可行性报告与经费预算框架的智能化撰写指南
数据库·人工智能·科技·mongodb·ui·rabbitmq·deepseek
2501_927773071 小时前
Linux系统编程——sqlite数据库
数据库