• 【Oracle】ORA-14400: 插入的分区关键字未映射到任何分区


    问题描述:

      工作中使用kettle将原始库中的数据抽取到标准库中,在抽取过程中报错:【ORA-14400: 插入的分区关键字未映射到任何分区】/【ORA-14400: inserted partition key does not map to any partition】

    解决过程:

    ORA-14400: 插入的分区关键字未映射到任何分区
    ORA-06512: 在 "NMS_FMS.BATCH_SAVE", line 1109

    ORA-06512: 在 line 1

    at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:331)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:288)
    at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:745)
    at oracle.jdbc.driver.T4CCallableStatement.doOall8(T4CCallableStatement.java:218)
    at oracle.jdbc.driver.T4CCallableStatement.executeForRows(T4CCallableStatement.java:969)
    at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1190)
    at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3370)
    at oracle.jdbc.driver.OraclePreparedStatement.execute(OraclePreparedStatement.java:3476)
    at oracle.jdbc.driver.OracleCallableStatement.execute(OracleCallableStatement.java:4400)
    at com.mchange.v2.c3p0.impl.NewProxyCallableStatement.execute(NewProxyCallableStatement.java:3044)

      经过百度,发现出现ORA-14400是表分区出现问题。  

      1.确定该表是否已经添加了表分区。    

    select partition_name,high_value from user_tab_partitions t where table_name='table_name';

      2.查询表分区绑定的字段名称。   

    select * from user_part_key_columns t where name='table_name';

      3.查看当前表分区的具体情况

    select * from user_tab_partitions t where table_name='table_name';

      4.查询表分区绑定的字段的最大值。注:此处的table_name应为当前表对应的原始库中的源表。

    select max(key_column) from table_name t;

      5.将查询到的表分区绑定字段的最大值插入到当前表中进行测试,发现报错。

    insert into table_name(table_column1,table_column2,......,key_column) values(value1,value2,......,key_value);

      6.经过以上环节确定源表中出现错误数据,并且由于错误数据的时间跨度大于当前分区的范围,导致ORA-14400错误的出现,但是由于该数据必须保留,因此对表分区进行扩展。

      7.扩展当前表分区以保证范围大于绑定字段的最大值。

    复制代码
    alter table  table_name add partition part_key_column_029 values less than (to_date('2029-01-01 00:00:00','YYYY-MM-DD HH24:MI:SS','NLS_CALENDAR=GREGORIAN'))
    
           tablespace tablespace_name
    
           pctfree 10
    
            initrans 1
    
           maxtrans255,
    
    ......,
    
    alter table  table_name add partition part_key_column_049 values less than (to_date('2049-01-01 00:00:00','YYYY-MM-DD HH24:MI:SS','NLS_CALENDAR=GREGORIAN'))
           tablespace tablespace_name        pctfree 10        initrans 1        maxtrans255,
    复制代码

      8.结束。再次使用kettle进行抽取时顺利抽取。

  • 相关阅读:
    mysql总结
    ContOS7 安装 java1.8
    查找
    排序
    线程通信(交替执行)
    死锁(实现)
    Rank Scores
    OpenMP
    聚类的数据量过大的问题
    编译GraphLab出错
  • 原文地址:https://www.cnblogs.com/learnspace/p/9510827.html
Copyright © 2020-2023  润新知