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用于指定传入对象的成员变量。