java.lang.Object
org.apache.arrow.vector.BaseValueVector
org.apache.arrow.vector.BaseFixedWidthVector
org.apache.arrow.vector.DurationVector
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Iterable<ValueVector>,- ElementAddressableVector,- FieldVector,- FixedWidthVector,- ValueIterableVector<Duration>,- ValueVector,- VectorDefinitionSetter
public final class DurationVector
extends BaseFixedWidthVector
implements ValueIterableVector<Duration>
DurationVector implements a fixed width vector (8 bytes) of a configurable TimeUnit granularity
 duration values which could be null. A validity buffer (bit vector) is maintained to track which
 elements in the vector are null.
- 
Field SummaryFieldsFields inherited from class org.apache.arrow.vector.BaseFixedWidthVectoractualValueCapacity, field, lastValueCapacity, valueBufferFields inherited from class org.apache.arrow.vector.BaseValueVectorallocator, fieldReader, INITIAL_VALUE_ALLOCATION, MAX_ALLOCATION_SIZE, MAX_ALLOCATION_SIZE_PROPERTY, validityBuffer, valueCount
- 
Constructor SummaryConstructorsConstructorDescriptionDurationVector(String name, FieldType fieldType, BufferAllocator allocator) Instantiate a DurationVector.DurationVector(Field field, BufferAllocator allocator) Instantiate a DurationVector.
- 
Method SummaryModifier and TypeMethodDescriptionget(int index) Get the element at the given index from the vector.voidget(int index, NullableDurationHolder holder) Get the element at the given index from the vector and sets the state in holder.static longGiven a data buffer, get the value stored at a particular position in the vector.getAsStringBuilder(int index) Get the Interval value at a given index as aStringBuilderobject.Get minor type for this vector.getObject(int index) Same asget(int).getObjectNotNull(int index) Same asgetObject(int)but does not check for null.protected FieldReaderEach vector has a different reader that implements the FieldReader interface.getTransferPair(String ref, BufferAllocator allocator) Construct a TransferPair comprising of this and a target vector of the same type.getTransferPair(Field field, BufferAllocator allocator) Construct a TransferPair comprising this and a target vector of the same type.getUnit()Gets the time unit of the duration.Construct a TransferPair with a desired target vector of the same type.voidset(int index, int isSet, long value) Store the given value at a particular position in the vector. isSet indicates whether the value is NULL or not.voidset(int index, long value) Set the element at the given index to the given value.voidSet the element at the given index to the given value.voidset(int index, DurationHolder holder) Set the element at the given index to the value set in data holder.voidset(int index, NullableDurationHolder holder) Set the element at the given index to the value set in data holder.voidsetSafe(int index, int isSet, long value) Same asset(int, int, long)except that it handles the case when index is greater than or equal to current value capacity of the vector.voidsetSafe(int index, long value) Same asset(int, long)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().voidSame asset(int, ArrowBuf)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().voidsetSafe(int index, DurationHolder holder) Same asset(int, DurationHolder)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().voidsetSafe(int index, NullableDurationHolder holder) Same asset(int, NullableDurationHolder)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().static DurationtoDuration(long value, TimeUnit unit) Converts the given value and unit to the appropriateDuration.Methods inherited from class org.apache.arrow.vector.BaseFixedWidthVectoraccept, allocateNew, allocateNew, allocateNewSafe, allocateValidityBuffer, clear, close, copyFrom, copyFromSafe, decrementAllocationMonitor, getBuffers, getBufferSize, getBufferSizeFor, getChildrenFromFields, getDataBuffer, getDataBufferAddress, getDataPointer, getDataPointer, getField, getFieldBuffers, getFieldInnerVectors, getName, getNullCount, getOffsetBuffer, getOffsetBufferAddress, getTransferPair, getTransferPair, getTransferPair, getTypeWidth, getValidityBuffer, getValidityBufferAddress, getValidityBufferValueCapacity, getValueBufferValueCapacity, getValueCapacity, getValueCount, handleSafe, hashCode, hashCode, incrementAllocationMonitor, initializeChildrenFromFields, isNull, isSafe, isSet, loadFieldBuffers, reAlloc, refreshValueCapacity, reset, set, set, setIndexDefined, setInitialCapacity, setNull, setSafe, setSafe, setValueCount, sliceAndTransferValidityBuffer, splitAndTransferTo, transferTo, validateScalars, zeroVectorMethods inherited from class org.apache.arrow.vector.BaseValueVectorcheckBufRefs, copyValidityBuffer, getAllocator, getReader, getValidityBufferSizeFromCount, iterator, releaseBuffer, splitAndTransferValidityBuffer, toString, transferBufferMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.arrow.vector.FieldVectorexportBuffer, exportCDataBuffers, getExportedCDataBufferCountMethods inherited from interface java.lang.IterableforEach, iterator, spliteratorMethods inherited from interface org.apache.arrow.vector.ValueIterableVectorgetValueIterable, getValueIteratorMethods inherited from interface org.apache.arrow.vector.ValueVectoraccept, allocateNew, allocateNewSafe, clear, close, copyFrom, copyFromSafe, getAllocator, getBuffers, getBufferSize, getBufferSizeFor, getDataBuffer, getField, getName, getNullCount, getOffsetBuffer, getReader, getTransferPair, getTransferPair, getTransferPair, getValidityBuffer, getValueCapacity, getValueCount, hashCode, hashCode, isNull, reAlloc, reset, setInitialCapacity, setValueCount, validate, validateFull
- 
Field Details- 
TYPE_WIDTHpublic static final byte TYPE_WIDTH- See Also:
 
 
- 
- 
Constructor Details- 
DurationVectorInstantiate a DurationVector. This doesn't allocate any memory for the data in vector.- Parameters:
- name- name of the vector
- fieldType- type of Field materialized by this vector
- allocator- allocator for memory management.
 
- 
DurationVectorInstantiate a DurationVector. This doesn't allocate any memory for the data in vector.- Parameters:
- field- field materialized by this vector
- allocator- allocator for memory management.
 
 
- 
- 
Method Details- 
getReaderImplDescription copied from class:BaseValueVectorEach vector has a different reader that implements the FieldReader interface. Overridden methods must make sure to return the correct concrete reader implementation.- Specified by:
- getReaderImplin class- BaseValueVector
- Returns:
- Returns a lambda that initializes a reader when called.
 
- 
getMinorTypeGet minor type for this vector. The vector holds values belonging to a particular type.- Specified by:
- getMinorTypein interface- ValueVector
- Returns:
- Types.MinorType
 
- 
getGiven a data buffer, get the value stored at a particular position in the vector.This method should not be used externally. - Parameters:
- buffer- data buffer
- index- position of the element.
- Returns:
- value stored at the index.
 
- 
getGet the element at the given index from the vector.- Parameters:
- index- position of element
- Returns:
- element at given index
- Throws:
- IllegalStateException
 
- 
getGet the element at the given index from the vector and sets the state in holder. If element at given index is null, holder.isSet will be zero.- Parameters:
- index- position of element
 
- 
getObjectSame asget(int).- Specified by:
- getObjectin interface- ValueVector
- Parameters:
- index- position of element
- Returns:
- element at given index
 
- 
getObjectNotNullSame asgetObject(int)but does not check for null.- Parameters:
- index- position of element
- Returns:
- element at given index
 
- 
toDurationConverts the given value and unit to the appropriateDuration.
- 
getAsStringBuilderGet the Interval value at a given index as aStringBuilderobject.- Parameters:
- index- position of the element
- Returns:
- String Builder object with Interval in java.time.Duration format.
 
- 
getUnitGets the time unit of the duration.
- 
setSet the element at the given index to the given value.- Parameters:
- index- position of element
- value- value of element
 
- 
setpublic void set(int index, long value) Set the element at the given index to the given value.- Parameters:
- index- position of element
- value- The duration value (in the timeunit associated with this vector)
 
- 
setSet the element at the given index to the value set in data holder. If the value in holder is not indicated as set, element in the at the given index will be null.- Parameters:
- index- position of element
- holder- nullable data holder for value of element
- Throws:
- IllegalArgumentException
 
- 
setSet the element at the given index to the value set in data holder.- Parameters:
- index- position of element
- holder- data holder for value of element
 
- 
setSafeSame asset(int, ArrowBuf)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().- Parameters:
- index- position of element
- value- value of element
 
- 
setSafepublic void setSafe(int index, long value) Same asset(int, long)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().- Parameters:
- index- position of element
- value- duration in the time unit this vector was constructed with
 
- 
setSafeSame asset(int, NullableDurationHolder)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().- Parameters:
- index- position of element
- holder- nullable data holder for value of element
- Throws:
- IllegalArgumentException
 
- 
setSafeSame asset(int, DurationHolder)except that it handles the case when index is greater than or equal to existing value capacityBaseFixedWidthVector.getValueCapacity().- Parameters:
- index- position of element
- holder- data holder for value of element
 
- 
setpublic void set(int index, int isSet, long value) Store the given value at a particular position in the vector. isSet indicates whether the value is NULL or not.- Parameters:
- index- position of the new value
- isSet- 0 for NULL value, 1 otherwise
- value- The duration value (in the TimeUnit associated with this vector).
 
- 
setSafepublic void setSafe(int index, int isSet, long value) Same asset(int, int, long)except that it handles the case when index is greater than or equal to current value capacity of the vector.- Parameters:
- index- position of the new value
- isSet- 0 for NULL value, 1 otherwise
- value- The duration value (in the timeunit associated with this vector)
 
- 
getTransferPairConstruct a TransferPair comprising of this and a target vector of the same type.- Specified by:
- getTransferPairin interface- ValueVector
- Specified by:
- getTransferPairin class- BaseFixedWidthVector
- Parameters:
- ref- name of the target vector
- allocator- allocator for the target vector
- Returns:
- TransferPair
 
- 
getTransferPairConstruct a TransferPair comprising this and a target vector of the same type.- Specified by:
- getTransferPairin interface- ValueVector
- Specified by:
- getTransferPairin class- BaseFixedWidthVector
- Parameters:
- field- Field object used by the target vector
- allocator- allocator for the target vector
- Returns:
- TransferPair
 
- 
makeTransferPairConstruct a TransferPair with a desired target vector of the same type.- Specified by:
- makeTransferPairin interface- ValueVector
- Parameters:
- to- target vector
- Returns:
- TransferPair
 
 
-