欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > IT业 > SQL主键回显

SQL主键回显

2025/4/29 2:01:03 来源:https://blog.csdn.net/m0_63624484/article/details/139560281  浏览:    关键词:SQL主键回显

目录

一 业务场景

二 如何使用


一 业务场景

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

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

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

二 如何使用

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

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

dishMapper.addDish(dish);

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

 Long dishId = dish.getId();

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词