我试图使用
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"});
原文地址:https://www.jb51.cc/java/127573.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。