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值啦!然后就可以按照需要赋值给你所需要的对象属性中去啦!

相关推荐
环流_13 分钟前
redis核心数据类型在java中的操作
java·数据库·redis
雨辰AI19 分钟前
SpringBoot3 项目国产化改造完整流程|从 MySQL 到人大金仓落地
java·数据库·后端·mysql·政务
一个天蝎座 白勺 程序猿21 分钟前
存储治理:表空间自动目录创建与国产操作系统生态适配
数据库·kingbasees
2401_8844541529 分钟前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
weelinking1 小时前
【企业级】企业级大模型合规实战:数据安全与跨境传输的技术解决方案
数据库·人工智能·机器学习·云计算·github
m0_470857641 小时前
golang如何实现目录大小统计_golang目录大小统计实现方案
jvm·数据库·python
rockey6271 小时前
AScript如何实现LINQ语法
sql·c#·.net·linq·script·eval·expression
穗余1 小时前
RAG为什么必须用向量数据库?
数据库
weixin_444012931 小时前
如何在多实例管理时隐藏MySQL版本信息_安全混淆与配置
jvm·数据库·python
weixin_459753941 小时前
SQL处理大规模分组聚合的内存限制_调整服务器配置
jvm·数据库·python