博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[oracle] 如何使用myBatis在数据库中插入数据并返回主键
阅读量:4682 次
发布时间:2019-06-09

本文共 1535 字,大约阅读时间需要 5 分钟。

在MyBatis中,希望在Oracle中插入数据的同时返回主键值,而非插入的条数。

① oracle使用 selectKey。

U_USER_INFO_SEQ 是在数据库中定义好的这张表关联的序列sequence,
Nextval是获取自增的id
SELECT U_USER_INFO_SEQ.Nextval as ID from DUAL
insert into U_USER_INFO
ID,
USER_NAME,
REAL_NAME,
.....

要点是这里使用了selectKey来定义返回新生成的PrimaryKey,这个情况仅仅适用于Oracle。

需要注意的地方是在Java代码中使用Integer类型,但是在MyBatis的映射文件中,使用java.math.BigDecimal类型,否则会报类型转换或者不匹配的错误。

其他比如MySQL或者SQLServer的情况适用于以下情况:

insert into spares(spares_id,spares_name, spares_type_id,spares_spec) values(#{id},#{name},#{typeId},#{spec})  

使用useGeneratedKeys/KeyProperty来实现插入数据的时候,来完成新生成主键的返回。

 

其中异常信息的解决:

异常信息:

   org.springframework.jdbc.UncategorizedSQLException: Error getting generated key or setting result to parameter object. Cause: java.sql.SQLException: 无效的列类型: getBigDecimal not implemented for class oracle.jdbc.driver.T4CRowidAccessor

; uncategorized SQLException for SQL []; SQL state [99999]; error code [17004]; 无效的列类型: getBigDecimal not implemented for class oracle.jdbc.driver.T4CRowidAccessor; nested exception is java.sql.SQLException:
无效的列类型: getBigDecimal not implemented for class oracle.jdbc.driver.T4CRowidAccessor

 

问题解决:

    问题是在Java代码中设置返回的主键数据类型,其中返回的数据类型为java.lang.Integer,而非BigDecimal和Long. 但是在MyBatis中的映射文件中的类型为java.math.BigDecimal.

转载于:https://www.cnblogs.com/avivaye/p/4179820.html

你可能感兴趣的文章
触屏智能手机界面可用性要素的纵贯式研究
查看>>
intent(2、隐形intent)
查看>>
JNA 备注
查看>>
vmware Linux虚拟机挂载共享文件夹
查看>>
argument 1 must be 2-item sequence, not int
查看>>
一个基本的MVC模式的增删改查
查看>>
Java开发环境安装过程
查看>>
C++ 利用栈解决运算问题
查看>>
Trie树
查看>>
__attribute__
查看>>
HTML中图像代替提交按钮
查看>>
jquery ajax contentType为application/json
查看>>
Python异常处理
查看>>
FD.io了解
查看>>
RIPng
查看>>
Internal Error 2738 - Installing ArcGIS Server 9.3,10 for Java
查看>>
hdu 1065 I Think I Need a Houseboat
查看>>
java Integer parseInt()
查看>>
初识JavaScript 变量, 操作符, 数组
查看>>
Ext中动态修改grid内容
查看>>