Sql 为什么即使我添加了jdbcType,插入也会失败,错误代码为17004?

Sql 为什么即使我添加了jdbcType,插入也会失败,错误代码为17004?,sql,spring,oracle,mybatis,Sql,Spring,Oracle,Mybatis,我一直在处理插入操作,它一直失败,错误代码为17004 <insert id="registerNewPenalty" parameterType="TbAdhPenaltyTreatVO"> INSERT INTO TB_ADH_PENALTYTREAT VALUES ( ( SELECT TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ FROM T

我一直在处理插入操作,它一直失败,错误代码为17004

<insert id="registerNewPenalty" parameterType="TbAdhPenaltyTreatVO">
INSERT INTO
    TB_ADH_PENALTYTREAT
VALUES (
    (
        SELECT
            TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ
        FROM
            TB_ADH_PENALTYTREAT
     ),
    #{penaltytpcd, jdbcType=VARCHAR},
    #{regdt, jdbcType=DATE},
    #{occurdt, jdbcType=DATE},
    #{runvioltpcd, jdbcType=DATE},
    #{compid, jdbcType=INTEGER},
    #{routeid, jdbcType=INTEGER},
    #{busid, jdbcType=INTEGER},
    'bmscenter',
    NULL,
    #{treat_detail, jdbcType=VARCHAR},
    '0'
)
</insert>
我认为问题是因为在insert中有一个select,但在oraclesqldeveloper中,它起了作用。错误代码17004是由于空值问题造成的,因此我还将jdbcType添加到我给出的每个参数中,但它仍然不起作用

这是我的SQL插入失败,错误代码为17004

<insert id="registerNewPenalty" parameterType="TbAdhPenaltyTreatVO">
INSERT INTO
    TB_ADH_PENALTYTREAT
VALUES (
    (
        SELECT
            TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ
        FROM
            TB_ADH_PENALTYTREAT
     ),
    #{penaltytpcd, jdbcType=VARCHAR},
    #{regdt, jdbcType=DATE},
    #{occurdt, jdbcType=DATE},
    #{runvioltpcd, jdbcType=DATE},
    #{compid, jdbcType=INTEGER},
    #{routeid, jdbcType=INTEGER},
    #{busid, jdbcType=INTEGER},
    'bmscenter',
    NULL,
    #{treat_detail, jdbcType=VARCHAR},
    '0'
)
</insert>
我在Oracle SQL Developer中期望和使用的查询是:

INSERT INTO tb_adh_penaltytreat
VALUES   (1,
         '1',
         SYSDATE,
         To_date('2017/11/02 04:40:47', 'YYYY/MM/DD HH24:MI:SS'),
         '13',
         '164003',
         '165000310',
         '7012268',
         'bmscenter',
         NULL,
         '......',
         '0'); 
对于顶部的查询,查询以以下日志结束:

[2019-01-29 16:03:17] DEBUG: org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
[2019-01-29 16:03:17] DEBUG: org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@777f6077]
[2019-01-29 16:03:17] DEBUG: org.mybatis.spring.transaction.SpringManagedTransaction - JDBC Connection [jdbc:oracle:thin:@10.10.10.20:1521:orcl, UserName=ICBIS_AGO, Oracle JDBC driver] will be managed by Spring
[2019-01-29 16:03:17] DEBUG: PENALTY.registerNewPenalty - ==>  Preparing: INSERT INTO TB_ADH_PENALTYTREAT VALUES ( ( SELECT TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ FROM TB_ADH_PENALTYTREAT ), ?, ?, ?, ?, ?, ?, ?, 'bmscenter', NULL, ?, '0' ) 
[2019-01-29 16:03:17] DEBUG: PENALTY.registerNewPenalty - ==> Parameters: 1(String), null, 2017-11-02 05:54:35.0(String), 13(String), 166012(String), 165000067(String), 7016047(String), this is for test.(String)
[2019-01-29 16:03:17] DEBUG: org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@777f6077]
我不知道问题是什么,但我怀疑这可能是选择的问题。 谢谢你的阅读

更新

我更改了我的查询,如下所示:

    <insert id="registerNewPenalty" parameterType="TbAdhPenaltyTreatVO">
    INSERT INTO
    TB_ADH_PENALTYTREAT (
        HISTNO,
        PENALTYTPCD,
        REGDT,
        OCCURDT,
        RUNVIOLTPCD,
        COMPID,
        ROUTEID,
        BUSID,
        TREAT_USERID,
        TREAT_ORGNM,
        TREAT_DETAIL,
        TREATYN
    )
    VALUES (
    (
        SELECT
            TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ
        FROM
            TB_ADH_PENALTYTREAT
     ),
    #{penaltytpcd, jdbcType=VARCHAR},
    SYSDATE,
    #{occurdt, jdbcType=DATE},
    #{runvioltpcd, jdbcType=DATE},
    #{compid, jdbcType=INTEGER},
    #{routeid, jdbcType=INTEGER},
    #{busid, jdbcType=INTEGER},
    'bmscenter',
    NULL,
    #{treat_detail, jdbcType=VARCHAR},
    '0'
    )
    </insert>
**第二次更新**

我已将{occurdt,jdbcType=DATE}更改为NULL,插入成功。所以我认为问题在于{occurdt,jdbcType=DATE}。

MyBatis不会自动添加到日期。您需要在语句中编写函数

截至{occurdt},'yyyyy/MM/DD HH24:MI:SS', 另一个选项是编写一个自定义函数,将字符串从日期转换为日期

{occurdt,typeHandler=com.xxx.YourCustomTypeHandler},
如果您可以控制VO定义,那么将属性类型更改为LocalDate或Date也是值得考虑的。然后{occurdt}应该可以工作。

在插入时列出列。问题可能是由于值进入了错误的列。依赖默认顺序是非常危险的。@GordonLinoff我按照你说的做了,但它仍然有一个问题:无论如何,谢谢你的建议。
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@5f587204]
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.transaction.SpringManagedTransaction - JDBC Connection [jdbc:oracle:thin:@10.10.10.20:1521:orcl, UserName=ICBIS_AGO, Oracle JDBC driver] will be managed by Spring
[2019-01-30 09:15:47] DEBUG: PENALTY.registerNewPenalty - ==>  Preparing: INSERT INTO TB_ADH_PENALTYTREAT ( HISTNO, PENALTYTPCD, REGDT, OCCURDT, RUNVIOLTPCD, COMPID, ROUTEID, BUSID, TREAT_USERID, TREAT_ORGNM, TREAT_DETAIL, TREATYN ) VALUES ( ( SELECT TO_CHAR(NVL(MAX(HISTNO), 0) + 1) AS MAXSEQ FROM TB_ADH_PENALTYTREAT ), ?, SYSDATE, ?, ?, ?, ?, ?, 'bmscenter', NULL, ?, '0' ) 
[2019-01-30 09:15:47] DEBUG: PENALTY.registerNewPenalty - ==> Parameters: 1(String), 2017-11-02 05:54:35.0(String), 13(String), 166012(String), 165000067(String), 7016047(String), This data is for test.(String)
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@5f587204]
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator - Unable to translate SQLException with Error code '1861', will now try the fallback translator
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.support.SQLStateSQLExceptionTranslator - Extracted SQL state class '22' from value '22008'
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.SqlSessionUtils - Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@5f587204]
[2019-01-30 09:15:47] DEBUG: org.mybatis.spring.SqlSessionUtils - Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@5f587204]
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.datasource.DataSourceTransactionManager - Initiating transaction rollback
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.datasource.DataSourceTransactionManager - Rolling back JDBC transaction on Connection [jdbc:oracle:thin:@10.10.10.20:1521:orcl, UserName=ICBIS_AGO, Oracle JDBC driver]
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.datasource.DataSourceTransactionManager - Releasing JDBC Connection [jdbc:oracle:thin:@10.10.10.20:1521:orcl, UserName=ICBIS_AGO, Oracle JDBC driver] after transaction
[2019-01-30 09:15:47] DEBUG: org.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource