欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

记一次mybatis插入oracle数据库报错的问题

程序员文章站 2022-07-13 08:05:24
...
org.springframework.dao.DuplicateKeyException: 
### Error updating database.  Cause: java.sql.SQLIntegrityConstraintViolationException: 调用中的无效参数
### SQL: insert into CUX.CUX_GL_PS ( HEADER_ID,SOURCE_SYSTEM,SYNONMY_CATEGORY,CLASS_NAME,BATCH_NUM,LEDGER_NAME,LINE_COUNT,SUM_DR_AMOUNT,SUM_CR_AMOUNT)values (CUX.CUX_GL_PS_S.nextval,?,?,?, ?,?,?,?,?)
### Cause: java.sql.SQLIntegrityConstraintViolationException: 调用中的无效参数
; SQL []; 调用中的无效参数; nested exception is java.sql.SQLIntegrityConstraintViolationException: 调用中的无效参数
	at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:239)
    <insert id="insertData" keyColumn="id" keyProperty="id" parameterType="com.aa.finance.entity.mysql.User" useGeneratedKeys="true">

问题原因:   keyColumn="id"  和表中的自增长列字段名称不一致,之前都是粘的不知道意思,真是脑残啊,普及一下这几个关键字的意思吧:
useGeneratedKeys=true表示使用数据库自动增长的主键,keyColumn用于指定数据库table中的主键,keyProperty用于指定传入对象的成员变量。