Uploaded image for project: 'Hive'
  1. Hive
  2. HIVE-20616

Dynamic Partition Insert failed if PART_VALUE exceeds 4000 chars

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Patch Available
    • Major
    • Resolution: Unresolved
    • None
    • None
    • None
    • None

    Description

      with mysql as metastore db the PARTITION_PARAMS.PARAM_VALUE defined as varchar(4000)

      describe PARTITION_PARAMS; 
      +-------------+---------------+------+-----+---------+-------+ 
      | Field | Type | Null | Key | Default | Extra | 
      +-------------+---------------+------+-----+---------+-------+ 
      | PART_ID | bigint(20) | NO | PRI | NULL | | 
      | PARAM_KEY | varchar(256) | NO | PRI | NULL | | 
      | PARAM_VALUE | varchar(4000) | YES | | NULL | | 
      +-------------+---------------+------+-----+---------+-------+ 
      

      which lead to the MoveTask failure if PART_VALUE excceeds 4000 chars.

      org.datanucleus.store.rdbms.exceptions.MappedDatastoreException: INSERT INTO `PARTITION_PARAMS` (`PARAM_VALUE`,`PART_ID`,`PARAM_KEY`) VALUES (?,?,?)
           at org.datanucleus.store.rdbms.scostore.JoinMapStore.internalPut(JoinMapStore.java:1074)
           at org.datanucleus.store.rdbms.scostore.JoinMapStore.putAll(JoinMapStore.java:224)
           at org.datanucleus.store.rdbms.mapping.java.MapMapping.postInsert(MapMapping.java:158)
           at org.datanucleus.store.rdbms.request.InsertRequest.execute(InsertRequest.java:522)
           at org.datanucleus.store.rdbms.RDBMSPersistenceHandler.insertObjectInTable(RDBMSPersistenceHandler.java:162)
           at org.datanucleus.store.rdbms.RDBMSPersistenceHandler.insertObject(RDBMSPersistenceHandler.java:138)
           at org.datanucleus.state.StateManagerImpl.internalMakePersistent(StateManagerImpl.java:3363)
           at org.datanucleus.state.StateManagerImpl.makePersistent(StateManagerImpl.java:3339)
           at org.datanucleus.ExecutionContextImpl.persistObjectInternal(ExecutionContextImpl.java:2080)
           at org.datanucleus.ExecutionContextImpl.persistObjectWork(ExecutionContextImpl.java:1923)
           at org.datanucleus.ExecutionContextImpl.persistObject(ExecutionContextImpl.java:1778)
           at org.datanucleus.ExecutionContextThreadedImpl.persistObject(ExecutionContextThreadedImpl.java:217)
           at org.datanucleus.api.jdo.JDOPersistenceManager.jdoMakePersistent(JDOPersistenceManager.java:724)
           at org.datanucleus.api.jdo.JDOPersistenceManager.makePersistent(JDOPersistenceManager.java:749)
           at org.apache.hadoop.hive.metastore.ObjectStore.addPartition(ObjectStore.java:2442)
           at sun.reflect.GeneratedMethodAccessor56.invoke(Unknown Source)
           at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
           at java.lang.reflect.Method.invoke(Method.java:498)
           at org.apache.hadoop.hive.metastore.RawStoreProxy.invoke(RawStoreProxy.java:97)
           at com.sun.proxy.$Proxy32.addPartition(Unknown Source)
           at org.apache.hadoop.hive.metastore.HiveMetaStore$HMSHandler.add_partition_core(HiveMetaStore.java:3976)
           at org.apache.hadoop.hive.metastore.HiveMetaStore$HMSHandler.add_partition_with_environment_context(HiveMetaStore.java:4032)
           at sun.reflect.GeneratedMethodAccessor54.invoke(Unknown Source)
           at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
           at java.lang.reflect.Method.invoke(Method.java:498)
           at org.apache.hadoop.hive.metastore.RetryingHMSHandler.invokeInternal(RetryingHMSHandler.java:147)
           at org.apache.hadoop.hive.metastore.RetryingHMSHandler.invoke(RetryingHMSHandler.java:108)
           at com.sun.proxy.$Proxy34.add_partition_with_environment_context(Unknown Source)
           at org.apache.hadoop.hive.metastore.api.ThriftHiveMetastore$Processor$add_partition_with_environment_context.getResult(ThriftHiveMetastore.java:15528)
           at org.apache.hadoop.hive.metastore.api.ThriftHiveMetastore$Processor$add_partition_with_environment_context.getResult(ThriftHiveMetastore.java:15512)
           at org.apache.thrift.ProcessFunction.process(ProcessFunction.java:39)
           at org.apache.thrift.TBaseProcessor.process(TBaseProcessor.java:39)
           at org.apache.hadoop.hive.metastore.security.HadoopThriftAuthBridge$Server$TUGIAssumingProcessor$1.run(HadoopThriftAuthBridge.java:636)
           at org.apache.hadoop.hive.metastore.security.HadoopThriftAuthBridge$Server$TUGIAssumingProcessor$1.run(HadoopThriftAuthBridge.java:631)
           at java.security.AccessController.doPrivileged(Native Method)
           at javax.security.auth.Subject.doAs(Subject.java:422)
           at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1688)
           at org.apache.hadoop.hive.metastore.security.HadoopThriftAuthBridge$Server$TUGIAssumingProcessor.process(HadoopThriftAuthBridge.java:631)
           at org.apache.thrift.server.TThreadPoolServer$WorkerProcess.run(TThreadPoolServer.java:286)
      
      Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'PARAM_VALUE' at row 1
           at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4185)
           at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4119)
           at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2570)
           at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2731)
           at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2820)
           at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2159)
           at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2462)
           at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2379)
           at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2363)
           at com.zaxxer.hikari.pool.ProxyPreparedStatement.executeUpdate(ProxyPreparedStatement.java:61)
           at com.zaxxer.hikari.pool.HikariProxyPreparedStatement.executeUpdate(HikariProxyPreparedStatement.java)
           at org.datanucleus.store.rdbms.ParamLoggingPreparedStatement.executeUpdate(ParamLoggingPreparedStatement.java:393)
           at org.datanucleus.store.rdbms.SQLController.executeStatementUpdate(SQLController.java:431)
           at org.datanucleus.store.rdbms.scostore.JoinMapStore.internalPut(JoinMapStore.java:1065)
           ... 41 more
      

      Attachments

        1. HIVE-20616.patch
          2 kB
          Rajkumar Singh

        Activity

          People

            Rajkumar Singh Rajkumar Singh
            Rajkumar Singh Rajkumar Singh
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

            Dates

              Created:
              Updated: