java – 有没有办法使用NamedParameterJdbcTemplate和GeneratedKeyHolder提
发布时间:2020-05-25 15:22:29 所属栏目:Java 来源:互联网
导读:我试图使用 Spring的NamedParameterJdbcTemplate和GeneratedKeyHolder提取ROWID或主键. 我想做这样的事情. MapSqlParameterSource parameters = new MapSqlParameterSource() .addValue(param1, value1)
|
我试图使用 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"}); (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
