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

来源:互联网 发布:如何将iphone投影到mac 编辑:程序博客网 时间:2024/05/16 11:10

我们在进行表的记录的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());
阅读全文
0 0
原创粉丝点击