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