java - jdbcTemplate插入MYSQL时怎么返回主键ID
高洛峰
高洛峰 2017-04-17 11:54:04
[Java讨论组]
    @Override
    public Integer add(Board board) {
        String sql = "INSERT INTO tz_board(title, description) VALUES(?,?)";
        jdbcTemplate.update(sql, board.getTitle(), board.getDescription());
        Integer boardId = jdbcTemplate.
        return boardId;
    }

不知道我这样写对不对

Integer boardId = jdbcTemplate.

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(3)
高洛峰
KeyHolder keyHolder = new GeneratedKeyHolder();
jdbcTemplate.update( new PreparedStatementCreator(){
                    @Override
                   public PreparedStatement createPreparedStatement(Connection conn) throws SQLException{
                        PreparedStatement ps = conn.prepareStatement(SQL_ADD, new String[] {}); 
                        ps = conn.prepareStatement(YOUR_SQL_SCRIPT, Statement.RETURN_GENERATED_KEYS);
                        ps.setString(1, "TEST");
                        ps.setInt(2, 1);
                        //...

                        return ps;
                    }
                },
                keyHolder);
return keyHolder.getKey().intValue();
黄舟

Spring提供了一个接口

org.springframework.jdbc.support.KeyHolder

其中有方法

getKey()

方法描述

Retrieve the first map of keys. If there are multiple entries in the list (meaning that multiple rows had keys returned), then an InvalidDataAccessApiUsageException is thrown.

PHPz

是滴,如楼上所言
org.springframework.jdbc.support.KeyHoldergetKey()方法返回注解,具体看如下例子

http://bailong139.blog.163.com/blog/static/207238100201331383516951/

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号