Spring jdbcTemplate 获取insert后主键自增的表的主键id

本文介绍了一种在Spring框架下通过jdbctemplate获取MySQL表插入记录后自动生成的主键ID的方法。针对多用户环境下可能存在的数据同步问题,演示了如何使用KeyHolder和PreparedStatementCreator来确保获取到正确的自增ID。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们在进行表的记录的insert 的操作之后。有这样的需求会需要得到insert 那条记录的主键id。并且该表的主键id是主键自增的。
如果使用MySQL的max函数是不可以的。因为此时在多个用户的情况下。数据表中其他用户也插入了数据。所以数据可能是不准确的。

上次笔者在纯的jdbc的情况下可以拿到该主键自增的id。spring的jdbctemplate只是对jdbc做了一个封装。也是可以做到的。而且代码简化地更加厉害。
下面演示下代码的片段。



        KeyHolder keyHolder = new GeneratedKeyHolder();
        PreparedStatementCreator preparedStatementCreator = con -> {
            PreparedStatement ps = con.prepareStatement("INSERT  INTO order_worker_quote_detail (work_quote_id, item_id, quantity, remarks) VALUES ('1','2','120','测试费用名')", Statement.RETURN_GENERATED_KEYS);
            return ps;
        };

        jdbcTemplate.update(preparedStatementCreator, keyHolder);

        System.out.println("看下能否拿到最终的自增的id-------------->" + keyHolder.getKey().longValue());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值