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

我们在进行表的记录的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());

你可能感兴趣的:(Java)