Class TimestampDataSerializer

java.lang.Object
org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
org.apache.flink.table.runtime.typeutils.TimestampDataSerializer
All Implemented Interfaces:
Serializable

@Internal public class TimestampDataSerializer extends org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
Serializer for TimestampData.

A TimestampData instance can be compactly serialized as a long value(= millisecond) when the Timestamp type is compact. Otherwise it's serialized as a long value and a int value.

See Also:
  • Nested Class Summary

    Nested Classes
    Modifier and Type
    Class
    Description
    static final class 
    TypeSerializerSnapshot for TimestampDataSerializer.
  • Constructor Summary

    Constructors
    Constructor
    Description
    TimestampDataSerializer(int precision)
     
  • Method Summary

    Modifier and Type
    Method
    Description
    void
    copy(org.apache.flink.core.memory.DataInputView source, org.apache.flink.core.memory.DataOutputView target)
     
    org.apache.flink.table.data.TimestampData
    copy(org.apache.flink.table.data.TimestampData from)
     
    org.apache.flink.table.data.TimestampData
    copy(org.apache.flink.table.data.TimestampData from, org.apache.flink.table.data.TimestampData reuse)
     
    org.apache.flink.table.data.TimestampData
     
    org.apache.flink.table.data.TimestampData
    deserialize(org.apache.flink.core.memory.DataInputView source)
     
    org.apache.flink.table.data.TimestampData
    deserialize(org.apache.flink.table.data.TimestampData reuse, org.apache.flink.core.memory.DataInputView source)
     
    org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
     
    boolean
     
    int
     
    int
     
    boolean
     
    void
    serialize(org.apache.flink.table.data.TimestampData record, org.apache.flink.core.memory.DataOutputView target)
     
    org.apache.flink.api.common.typeutils.TypeSerializerSnapshot<org.apache.flink.table.data.TimestampData>
     

    Methods inherited from class java.lang.Object

    clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
  • Constructor Details

    • TimestampDataSerializer

      public TimestampDataSerializer(int precision)
  • Method Details

    • isImmutableType

      public boolean isImmutableType()
      Specified by:
      isImmutableType in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • duplicate

      public org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData> duplicate()
      Specified by:
      duplicate in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • createInstance

      public org.apache.flink.table.data.TimestampData createInstance()
      Specified by:
      createInstance in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • copy

      public org.apache.flink.table.data.TimestampData copy(org.apache.flink.table.data.TimestampData from)
      Specified by:
      copy in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • copy

      public org.apache.flink.table.data.TimestampData copy(org.apache.flink.table.data.TimestampData from, org.apache.flink.table.data.TimestampData reuse)
      Specified by:
      copy in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • getLength

      public int getLength()
      Specified by:
      getLength in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • serialize

      public void serialize(org.apache.flink.table.data.TimestampData record, org.apache.flink.core.memory.DataOutputView target) throws IOException
      Specified by:
      serialize in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
      Throws:
      IOException
    • deserialize

      public org.apache.flink.table.data.TimestampData deserialize(org.apache.flink.core.memory.DataInputView source) throws IOException
      Specified by:
      deserialize in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
      Throws:
      IOException
    • deserialize

      public org.apache.flink.table.data.TimestampData deserialize(org.apache.flink.table.data.TimestampData reuse, org.apache.flink.core.memory.DataInputView source) throws IOException
      Specified by:
      deserialize in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
      Throws:
      IOException
    • copy

      public void copy(org.apache.flink.core.memory.DataInputView source, org.apache.flink.core.memory.DataOutputView target) throws IOException
      Specified by:
      copy in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
      Throws:
      IOException
    • equals

      public boolean equals(Object obj)
      Specified by:
      equals in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • hashCode

      public int hashCode()
      Specified by:
      hashCode in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>
    • snapshotConfiguration

      public org.apache.flink.api.common.typeutils.TypeSerializerSnapshot<org.apache.flink.table.data.TimestampData> snapshotConfiguration()
      Specified by:
      snapshotConfiguration in class org.apache.flink.api.common.typeutils.TypeSerializer<org.apache.flink.table.data.TimestampData>