java – 有没有办法使用NamedParameterJdbcTemplate和GeneratedKeyHolder提取主键(或ROWID)?

我试图使用 Spring的NamedParameterJdbcTemplate和GeneratedKeyHolder提取ROWID或主键.

我想做这样的事情.

MapsqlParameterSource parameters = new MapsqlParameterSource()
                .addValue("param1",value1)
                .addValue("param2",value2);
KeyHolder keyHolder = new GeneratedKeyHolder();
namedParameterJdbcTemplate.update("INSERT INTO TABLE(ID,col1,col2)"
                + "VALUES(TABLE.TABLE_SEQ.NEXTVAL,:param1,:param2)",parameters,keyHolder);

执行上面的查询后,当我尝试执行keyHolder.getKey().longValue()时,它抛出异常.

HTTP Status 500 - Request processing Failed; nested exception is org.springframework.dao.DataRetrievalFailureException: The generated key is not of a supported numeric type. Unable to cast [oracle.sql.ROWID] to [java.lang.Number]

当我通过这个http://docs.oracle.com/cd/B28359_01/java.111/b31224/datacc.htm时,我理解(我希望我这样做)ojdbc没有将oracle RowId映射到java RowId.

任何人都可以建议有什么方法可以提取密钥吗? (是的,它可以使用PreparedStatement完成,但它使我的代码在某些条件下阅读和操作有点难看).非常感谢您的建议.

解决方法

你必须使用它
namedParameterJdbcTemplate.update("INSERT INTO TABLE(ID,col2)"
            + "VALUES(TABLE.TABLE_SEQ.NEXTVAL,keyHolder,new String[]{"ID"});

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...