Class Tuple
- All Implemented Interfaces:
- com.streambase.sb.internal.CloneableData,- Serializable,- Cloneable
- Direct Known Subclasses:
- CompiledTuple
 To create a new Tuple object, use the Schema.createTuple() method on
 a Schema instance.
 
 The DataType of each Field must be appropriate for the get and set methods invoked on the
 Field.  For example, the getDouble(Schema.Field) & setDouble(Schema.Field, double) methods work
 only on double fields.  The setField(Schema.Field, Object) will do default conversions from
 different types.
 
 For performance-critical paths, use the type-specific get and set methods that take a parameter of type Schema.Field (as opposed
 to the the methods that take an int or a String).
 
 Note that all methods accepting a Schema.Field argument will throw an IllegalArgumentException
 if the Field object was not obtained from the Schema associated with this Tuple instance (getSchema()).
 
This class is not thread safe. If instances of this class are accessed from multiple threads, access must be synchronized.
 Note:  Serializations of instances of this class that are created (e.g., by using
 ObjectOutputStream) in one version of StreamBase in general will not be
 deserializable in any other version of StreamBase.
 
Note: The Serialization feature is DEPRECATED and will be removed in a future release.
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classA default formatter that converts each type to String using Java default String conversions.static interfaceAn interface containing flags returned from certain setXXXX callsstatic interfaceThis interface is not public API, and should not be implemented by users.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected static final intduring a get create tuple if it is nullstatic final TupleAn empty tupleprotected static final intno flagsstatic final StringThe default String representation of a null valued field (value "null")protected static final intduring a get throw an exception on null
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidcheckType(Schema.Field resolvedField, DataType dataType) Check typeprotected intcheckTypeAndNonNull(Schema.Field resolvedField, DataType dataType) check the type and make sure it is non nullabstract voidclear()Sets all of this tuple's fields to null values.clone()Clone this tuple, the new tuple will not share any buffers or data with the originalvoidcopyField(Schema.Field sourceField, Tuple destTuple, Schema.Field destField) Copy the field from this tuple to the destination tupleprotected voidcopy the source tuple to this tupleabstract TupleReturn a new tuple that is guaranteed to be read onlyabstract TupleReturn a new tuple that is guaranteed to be writablebooleanTest whether the given object is equal to this one.final TuplegetAllocatedTuple(int fieldIndex) Return a reference (not a copy) to the specified nested tuple field.getAllocatedTuple(Schema.Field field) Return a reference (not a copy) to the specified nested tuple field.final TuplegetAllocatedTuple(String fieldPathName) Return a reference (not a copy) to the specified nested tuple field.final ByteArrayViewgetBlobBuffer(int fieldIndex) Return a ByteArrayView for a given blob field.getBlobBuffer(Schema.Field field) Return a ByteArrayView for a given blob field.final ByteArrayViewgetBlobBuffer(String fieldPathName) Return a ByteArrayView for a given blob field.final booleangetBoolean(int fieldIndex) Return the value of the boolean field at a specified field index.booleangetBoolean(Schema.Field field) Return the value of a specified boolean field.final booleangetBoolean(String fieldPathName) Return the value of a named boolean field.final TuplegetCapture(int fieldIndex) Return the value of the named capture field.final TuplegetCapture(Schema.Field field) Return the value of the named capture field.final TuplegetCapture(String fieldPathName) Return the value of the named capture field.protected abstract TuplegetCaptureImpl(Schema.Field field) Get capture fieldfinal doublegetDouble(int fieldIndex) Return the value of the double field at a specified field index.doublegetDouble(Schema.Field field) Return the value of a specified double field.final doubleReturn the value of a named double field.final ObjectgetField(int fieldIndex) Return the value of the field at a specified field index.final ObjectgetField(Schema.Field field) Return the value of a specified field.final ObjectReturn the value of a named field.final StringgetFieldAsString(Schema.Field field, Tuple.TupleFormatter formatter) Get the current field as a human readable string, using theTuple.TupleFormatterprovided.Deprecated.final FunctiongetFunction(int fieldIndex) Return the value of the function field at a specified field index.final FunctiongetFunction(Schema.Field field) Return the value of the given function field.final FunctiongetFunction(String fieldName) Return the value of the named function field.final intgetInt(int fieldIndex) Return the value of the int field at a specified field index.intgetInt(Schema.Field field) Return the value of a specified int field.final intReturn the value of a named int field.final List<?> getList(int fieldIndex) Return the value of the list field at a specified field index.List<?> getList(Schema.Field field) Return the value of a specified list field.final List<?> Return the value of a named list field.final longgetLong(int fieldIndex) Return the value of the long field at a specified field index.longgetLong(Schema.Field field) Return the value of a specified long field.final longReturn the value of a named long field.final SchemaReturn the Schema for this Tuplefinal StringgetString(int fieldIndex) Return the value of the named string field.getString(Schema.Field field) Return the value of a specified string field.final StringReturn the value of the named string field.final TimestampgetTimestamp(int fieldIndex) Return the value of the timestamp field at a specified field index.getTimestamp(Schema.Field field) Return the value of a specified timestamp field.final TimestampgetTimestamp(String fieldPathName) Return the value of a named timestamp field.final TuplegetTuple(int fieldIndex) Return a reference (not a copy) to the specified nested tuple field.getTuple(Schema.Field field) Return a reference (not a copy) to the specified nested tuple field.final TupleReturn a reference (not a copy) to the specified nested tuple field.static Tuple.TupleFormatterReturns a shared instance of the default tuple field formatter that converts each type to String using Java default String conversions.inthashCode()Compute a hashCode for the object.final booleanisNull(int fieldIndex) Determines whether a field in the tuple is null.booleanisNull(Schema.Field field) Determines whether the given field's value in this Tuple is null.final booleanDetermines whether a field in the tuple is null.abstract booleanReturns true if this is a read only tuple (read only tuples throw an UnsupportedOperationException when setter methods are called)final voidserialize(com.streambase.sb.util.ByteOrderedDataOutput output) Serialize this tuple into a ByteOrderedDataOutputabstract voidserialize(com.streambase.sb.util.ByteOrderedDataOutput output, int tupleId) Serialize this tuple into a ByteOrderedDataOutput while specifing the tupleId.final voidsetBlobBuffer(int fieldIndex, ByteArrayView value) Set the blob field at a specified field index to a copy of a specified blob.voidsetBlobBuffer(Schema.Field field, ByteArrayView value) Set a specified blob field to a copy of a specified blob.final voidsetBlobBuffer(String fieldPathName, ByteArrayView value) Set a named blob field to a copy of a specified blob.final voidsetBoolean(int fieldIndex, boolean value) Set the boolean field at a specified field index to a specified value.voidsetBoolean(Schema.Field field, boolean value) Set a named boolean field to a specified value.final voidsetBoolean(String fieldPathName, boolean value) Set a named boolean field to a specified value.final voidsetCapture(int field, Tuple value) Set a specified capture field to a copy of a specified tuple.final voidsetCapture(Schema.Field field, Tuple value) Set a specified capture field to a copy of a specified tuple.final voidsetCapture(String field, Tuple value) Set a specified capture field to a copy of a specified tuple.final voidsetDouble(int fieldIndex, double value) Set the double field at a specified field index to a specified value.voidsetDouble(Schema.Field field, double value) Set a named double field to a specified value.final voidSet a named double field to a specified value.final voidSet the field at a specified field index to a specified boxed value.final voidsetField(Schema.Field field, Object value) Set a specified field to a specified boxed value.final voidsetField(Schema.Field field, Object value, com.streambase.sb.util.CSV.FormatInfo format) Set the field at a specified field name to a specified boxed value.final voidSet the named field to a specified value.final voidSet the field at a specified field name to a specified boxed value.voidTakes a map of field names and values as Objects and sets the corresponding tuple field with the supplied value.final voidsetFunction(int field, Function value) Set a specified function field to the givenFunctionfinal voidsetFunction(Schema.Field field, Function value) Set a specified function field to the givenFunctionfinal voidsetFunction(String field, Function value) Set a specified function field to the givenFunctionfinal voidsetInt(int fieldIndex, int value) Set the int field at a specified field index to a specified value.voidsetInt(Schema.Field field, int value) Set a specified int field to a specified value.final voidSet the named int field to a specified value.final voidSet the list field at a specified field index to a copy of the specified value.voidsetList(Schema.Field field, List<?> value) Set a specified list field to a copy of a specified value.final voidSet a named list field to a copy of a specified value.final voidsetLong(int fieldIndex, long value) Set the long field at a specified field index to a specified value.voidsetLong(Schema.Field field, long value) Set a specified long field to a specified value.final voidSet a named long field to a specified value.final voidsetNull(int fieldIndex) Set the field at a specified field index to null.voidsetNull(Schema.Field field) Set the specified field to nullfinal voidSet a named field to null.final voidsetString(int fieldIndex, CharSequence value) Set the string field at a specified field index to a specified value.final voidsetString(Schema.Field field, CharSequence value) Set a specified string field to a specified value.final voidsetString(String fieldPathName, CharSequence value) Set a named field to a specified value.final voidsetTimestamp(int fieldIndex, Timestamp value) Set the timestamp field at a specified field index to a specified value.voidsetTimestamp(Schema.Field field, Timestamp value) Set a named timestamp field to a specified value.final voidsetTimestamp(String fieldPathName, Timestamp value) Set a named timestamp field to a specified value.final voidSet a specified nested tuple field to that of the specified tuple.voidsetTuple(Schema.Field field, Tuple value) Set a specified nested tuple field to that of the specified tuple NOTE: A copy of the the tuple may be made to convert the given tuple to the appropriate internal representation.final voidSet a named nested tuple field to a specified tuple.toDelimitedString(char delimiter) Return the tuple as a string delimited by the given character.Returns a view on this Tuple that implements the Map<String, Object> interface.toString(boolean verbose) Return a string representation of this Tuple.toString(char delimiter, char quoteChar, boolean verbose) Return a string representation of this Tuple.toString(char delimiter, char quoteChar, boolean verbose, boolean showTupleId) Return a string representation of this Tuple.Return a string representation of this Tuple.Return a string representation of this Tuple.
- 
Field Details- 
EMPTY_TUPLEAn empty tuple
- 
NO_FLAGSprotected static final int NO_FLAGSno flags- See Also:
 
- 
THROW_ON_NULLprotected static final int THROW_ON_NULLduring a get throw an exception on null- See Also:
 
- 
CREATE_IF_NULLprotected static final int CREATE_IF_NULLduring a get create tuple if it is null- See Also:
 
- 
NULL_STRINGThe default String representation of a null valued field (value "null")- See Also:
 
 
- 
- 
Method Details- 
isReadOnlypublic abstract boolean isReadOnly()Returns true if this is a read only tuple (read only tuples throw an UnsupportedOperationException when setter methods are called)- Returns:
- true if this is a read only tuple
 
- 
cloneClone this tuple, the new tuple will not share any buffers or data with the original- Specified by:
- clonein interface- com.streambase.sb.internal.CloneableData
- Overrides:
- clonein class- Object
- Returns:
- A copy of this Tuple
- Throws:
- CloneNotSupportedException
 
- 
getSchema
- 
clearpublic abstract void clear()Sets all of this tuple's fields to null values.
- 
serializepublic final void serialize(com.streambase.sb.util.ByteOrderedDataOutput output) Serialize this tuple into a ByteOrderedDataOutput- Parameters:
- output- the output stream
 
- 
serializepublic abstract void serialize(com.streambase.sb.util.ByteOrderedDataOutput output, int tupleId) Serialize this tuple into a ByteOrderedDataOutput while specifing the tupleId. In general users will want to useserialize(ByteOrderedDataOutput)- Parameters:
- output- the output stream
- tupleId- the tupleId to attach to this tuple
- See Also:
 
- 
getBooleanReturn the value of a named boolean field.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a boolean for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getBooleanReturn the value of the boolean field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a boolean for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getBooleanReturn the value of a specified boolean field.- Parameters:
- field- the field to get
- Returns:
- a boolean for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getDoubleReturn the value of a named double field.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a double for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getDoubleReturn the value of the double field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a double for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getDoubleReturn the value of a specified double field.- Parameters:
- field- the double field to get
- Returns:
- a double for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getIntReturn the value of a named int field.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- an int for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getIntReturn the value of the int field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- an int for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getIntReturn the value of a specified int field.- Parameters:
- field- the int field to get
- Returns:
- an int for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getLongReturn the value of a named long field.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a long for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getLongReturn the value of the long field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a long for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getLongReturn the value of a specified long field.- Parameters:
- field- the long field to get
- Returns:
- a long for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getListReturn the value of a named list field. The returned list is not a copy and should not be modified. (The effects of such modifications are undefined.)- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a list for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
- Since:
- 6.3
 
- 
getListReturn the value of the list field at a specified field index. The returned list is not a copy and should not be modified. (The effects of such modifications are undefined.)- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a List for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
- Since:
- 6.3
 
- 
getListReturn the value of a specified list field. The returned list is not a copy and should not be modified. (The effects of such modifications are undefined.)- Parameters:
- field- the list field to get
- Returns:
- a list for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
- Since:
- 6.3
 
- 
getStringReturn the value of the named string field. Note that this method is not to be used to retrieve a String value for fields of any type: for that usegetField(String).- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a String for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getStringReturn the value of the named string field. Note that this method is not to be used to retrieve a String value for fields of any type: for that usegetField(String).- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a String for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getStringReturn the value of a specified string field. getString() will only work on String datatypes Use getField() to work on all datatypes- Parameters:
- field- the field
- Returns:
- a String for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getTimestampReturn the value of a named timestamp field.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a Timestamp for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getTimestampReturn the value of the timestamp field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a Timestamp for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getTimestampReturn the value of a specified timestamp field.- Parameters:
- field- the Timestamp field to get
- Returns:
- a Timestamp for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getBlobBufferpublic final ByteArrayView getBlobBuffer(String fieldPathName) throws TupleException, NullValueException Return a ByteArrayView for a given blob field. A copy of the blob is not made.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a ByteArrayView for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
 
- 
getBlobBufferReturn a ByteArrayView for a given blob field. A copy of the blob is not made.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a ByteArrayView for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
 
- 
getBlobBufferReturn a ByteArrayView for a given blob field. A copy of the blob is not made.- Parameters:
- field- the field to get
- Returns:
- a ByteArrayView for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
 
- 
getTupleReturn a reference (not a copy) to the specified nested tuple field. Also consider using {link #getAllocatedTuple(Schema.Field) as an alternative to reduce copying of data without the need for asetTuple(Schema.Field, Tuple).- Parameters:
- field- the field to get
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the Field provided
- Since:
- 6.0
- See Also:
 
- 
getAllocatedTupleReturn a reference (not a copy) to the specified nested tuple field. Allocates nested tuples as needed to always return a non-null tuple. The returned Tuple may be modified directly without the need to callsetTuple(Schema.Field, Tuple)to update the parent tuple.- Parameters:
- field- the field to get
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error
- Since:
- 6.6.12
 
- 
getTupleReturn a reference (not a copy) to the specified nested tuple field. Also consider using {link #getAllocatedTuple(String) as an alternative to reduce copying of data without the need for asetTuple(String, Tuple).- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
- Since:
- 6.0
- See Also:
 
- 
getAllocatedTupleReturn a reference (not a copy) to the specified nested tuple field. Allocates nested tuples as needed to always return a non-null tuple. The returned Tuple may be modified directly without the need to callsetTuple(Schema.Field, Tuple)to update the parent tuple.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error
- Since:
- 6.6.12
 
- 
getTupleReturn a reference (not a copy) to the specified nested tuple field. Also consider using {link #getAllocatedTuple(int) as an alternative to reduce copying of data without the need for asetTuple(int, Tuple).- Parameters:
- fieldIndex- the index of a field to get (starting at 0)
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null or a null sub-field was encountered while traversing to the field provided
- Since:
- 6.0
- See Also:
 
- 
getAllocatedTupleReturn a reference (not a copy) to the specified nested tuple field. Allocates nested tuples as needed to always return a non-null tuple. The returned Tuple may be modified directly without the need to callsetTuple(Schema.Field, Tuple)to update the parent tuple.- Parameters:
- fieldIndex- the index of a field to get (starting at 0)
- Returns:
- a Tuple for the given field
- Throws:
- TupleException- if there was a conversion error
- Since:
- 6.6.12
 
- 
getCaptureReturn the value of the named capture field.- Parameters:
- field- the field to get
- Returns:
- an Tuple containing the fields captured (possibly none)
- Throws:
- TupleException- on error with the capture field
- Since:
- 7.2
 
- 
getCaptureReturn the value of the named capture field.- Parameters:
- fieldPathName- the field to get
- Returns:
- an Tuple containing the fields captured (possibly none)
- Throws:
- TupleException- on error with the capture field
- NullValueException- if the value of the field is null
- Since:
- 7.2
 
- 
getCaptureReturn the value of the named capture field.- Parameters:
- fieldIndex- the index of the field to get
- Returns:
- an Tuple containing the fields captured (possibly none)
- Throws:
- TupleException- on error with the capture field
- NullValueException- if the value of the field is null
- Since:
- 7.2
 
- 
getCaptureImplGet capture field- Parameters:
- field- Field
- Returns:
- Capture field tuple
- Throws:
- TupleException- Error access capture field
 
- 
getFieldReturn the value of a specified field.- Parameters:
- field- the field to get
- Returns:
- an Object of the proper type for this field. Note that null will be returned if the field's value is null or a null sub-field was encountered while traversing to the field provided
- Throws:
- RuntimeException- if the field doesn't exist
 
- 
getFieldReturn the value of the field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- an Object of the proper type for this field. Note that null will be returned if the field's value is null.
- Throws:
- TupleException- if the field doesn't exist
 
- 
getFieldAsStringGet the current field as a human readable string, using theTuple.TupleFormatterprovided. StreamBase provides a default formatter viagetTupleFormatter()as a convenience.- Parameters:
- field- the field to get
- formatter- used to format the field value
- Returns:
- a string representation of the field
- Throws:
- RuntimeException- if there was a conversion error or if the field doesn't exist (also applies to fields contained in a field of type Tuple whose current value is null)
 
- 
getFieldReturn the value of a named field. See type-specific getStreamBaseType() methods for information related to the fields of each specific type.Escaping field names and path segments: Path name segments may begin with #"(hash, double-quote) and end with"(double-quote) in order to escape normally disallowed characters. When using this syntax, all inner quotes and backslashes must be escaped with backslashes, similar to syntax used for SSQL string literals.- Parameters:
- fieldPathName- the path name of the field to get
- Returns:
- an Object of the proper type for this field. Note that null will be returned if the field's value is null or a null sub-field was encountered while traversing to the field provided
- Throws:
- TupleException- if the field doesn't exist
 
- 
isNullDetermines whether a field in the tuple is null.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Returns:
- true if the field's value is null, false otherwise
- Throws:
- TupleException- when a field with the given path name does not exist in this Tuple
- IllegalArgumentException- If the field is not part of the Tuple's schema
- Error- If there was an error accessing a nested Tuple
 
- 
isNullDetermines whether a field in the tuple is null.- Parameters:
- fieldIndex- the index (0-based) of the field to check for a null value
- Returns:
- true if the field's value is null, false otherwise
- Throws:
- TupleException- when a field with the given path name does not exist in this Tuple
- IllegalArgumentException- If the field is not part of the Tuple's schema
- Error- If there was an error accessing a nested Tuple
 
- 
isNullDetermines whether the given field's value in this Tuple is null.The Field objects used to set and get Tuple field values must be obtained via the Tuple's Schema object. A Field object that has been created by the user or retrieved from a different Schema will not work and will throw an exception. - Parameters:
- field- the field to check for a null value
- Returns:
- true if the field's value is null (or a sub-field encountered while traversing to the given field was null), false otherwise
- Throws:
- IllegalArgumentException- If the field is not part of the Tuple's schema
- Error- If there was an error accessing a nested Tuple
 
- 
setBooleanpublic final void setBoolean(String fieldPathName, boolean value) throws TupleException, NullValueException Set a named boolean field to a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setBooleanpublic final void setBoolean(int fieldIndex, boolean value) throws TupleException, NullValueException Set the boolean field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setBooleanSet a named boolean field to a specified value.- Parameters:
- field- the field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setDoublepublic final void setDouble(String fieldPathName, double value) throws TupleException, NullValueException Set a named double field to a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setDoubleSet the double field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setDoubleSet a named double field to a specified value.- Parameters:
- field- the field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setIntSet the named int field to a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setIntSet the int field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setIntSet a specified int field to a specified value.- Parameters:
- field- the field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setBlobBufferSet a named blob field to a copy of a specified blob.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setBlobBufferSet the blob field at a specified field index to a copy of a specified blob.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setBlobBufferSet a specified blob field to a copy of a specified blob.- Parameters:
- field- the field to set
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setLongpublic final void setLong(String fieldPathName, long value) throws TupleException, NullValueException Set a named long field to a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setLongSet the long field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
 
- 
setLongSet a specified long field to a specified value.- Parameters:
- field- the field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setListpublic final void setList(String fieldPathName, List<?> value) throws TupleException, NullValueException Set a named list field to a copy of a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
- Since:
- 6.3
 
- 
setListSet the list field at a specified field index to a copy of the specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value of the field is null
- Since:
- 6.3
 
- 
setListSet a specified list field to a copy of a specified value.- Parameters:
- field- the field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 6.3
 
- 
setStringSet a named field to a specified value. Works only on String types, use setField() to coerce type.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- Since:
- 6.5 CharSequence version of method added
 
- 
setStringSet the string field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- Since:
- 6.5 CharSequence version of method added
 
- 
setStringSet a specified string field to a specified value.- Parameters:
- field- The field to set
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- Since:
- 6.5 CharSequence version of method added
 
- 
setTimestampSet a named timestamp field to a specified value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setTimestampSet the timestamp field at a specified field index to a specified value.- Parameters:
- fieldIndex- The index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setTimestampSet a named timestamp field to a specified value.- Parameters:
- field- The field to set
- value- the value to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
setTupleSet a named nested tuple field to a specified tuple.NOTE: A copy of the tuple may be made to convert the given tuple to the appropriate internal representation. Use getAllocatedTuple(String)if you require a reference (not a copy) of the nested tuple to achieve a zero copy setTuple. For example:Tuple nestedReference = tuple.getAllocatedTuple("fieldName"); nestedReference.set...; nestedReference.set...; // tuple.setTuple("fieldName", nestedReference); is not needed- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setTupleSet a specified nested tuple field to that of the specified tuple.NOTE: A copy of the tuple may be made to convert the given tuple to the appropriate internal representation. Use getAllocatedTuple(Schema.Field)if you require a reference (not a copy) of the nested tuple to achieve a zero copy setTuple. For example:Tuple nestedReference = tuple.getAllocatedTuple(field); nestedReference.set...; nestedReference.set...; // tuple.setTuple("fieldName", nestedReference); is not needed- Parameters:
- fieldIndex- the index of the field to set (starting at 0)
- value- the value to set the field to
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setTupleSet a specified nested tuple field to that of the specified tuple NOTE: A copy of the the tuple may be made to convert the given tuple to the appropriate internal representation. UsegetAllocatedTuple(Schema.Field)if you require a reference (not a copy) of the nested tuple For a zero copy setTuple do the following:Tuple nestedReference = tuple.getAllocatedTuple(field); nestedReference.set...; nestedReference.set...; // tuple.setTuple(field, nestedReference); is not needed and // in fact would cause an extra copy- Parameters:
- field- the field to set
- value- the tuple to set the field to
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
 
- 
getFieldsDeprecated.usetoMapView()Return a Map containing a list of all the field values of the tuple as Objects. The key is the field name as a String.- Returns:
- A Map containing all values from the tuple. Note that if the field is null in the tuple, it will not be included in the returned Map.
- Since:
- 6.0
- See Also:
 
- 
setFieldsTakes a map of field names and values as Objects and sets the corresponding tuple field with the supplied value. All fields not present in the map are set to null in the tuple.- Parameters:
- fields- map of field names and values
- Throws:
- TupleException- thrown if there was a conversion error
- Since:
- 7.4 no longer throws an error if the input map length does not match this Tuple's fieldcount
 
- 
setCaptureSet a specified capture field to a copy of a specified tuple.- Parameters:
- field- the field to set
- value- the value to set the field to. Must be of the correct type for this capture field
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 7.2
 
- 
setCaptureSet a specified capture field to a copy of a specified tuple.- Parameters:
- field- the field to set
- value- the value to set the field to. Must be of the correct type for this capture field
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 7.2
 
- 
setCaptureSet a specified capture field to a copy of a specified tuple.- Parameters:
- field- the field to set
- value- the value to set the field to. Must be of the correct type for this capture field
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 7.2
 
- 
getFunctionReturn the value of the function field at a specified field index.- Parameters:
- fieldIndex- the index of the field to get (starting at 0)
- Returns:
- a Functionfor the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
- Since:
- 7.4
 
- 
getFunctionReturn the value of the named function field.- Parameters:
- fieldName- the name of the field to get
- Returns:
- a Functionfor the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
- Since:
- 7.4
 
- 
getFunctionReturn the value of the given function field.- Parameters:
- field- the field to get
- Returns:
- a Functionfor the given field
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
- NullValueException- if the value is null
- Since:
- 7.4
 
- 
setFunctionSet a specified function field to the givenFunction- Parameters:
- field- the index of the field to set
- value- the value to set the field to. Must be of the correct type for this function field.
- Throws:
- TupleException- if there was a value conversion error, or the field doesn't exist in this Tuple.
- Since:
- 7.4
 
- 
setFunctionSet a specified function field to the givenFunction- Parameters:
- field- the name or path of the field to set
- value- the value to set the field to. Must be of the correct type for this function field
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 7.4
 
- 
setFunctionSet a specified function field to the givenFunction- Parameters:
- field- the field to set
- value- the value to set the field to. Must be of the correct type for this function field. This can be null to set this field to null.
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 7.4
 
- 
setFieldSet the named field to a specified value.See setField(Schema.Field, Object)for a discussion of possible conversions of the value.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setFieldpublic final void setField(String fieldPathName, Object value, com.streambase.sb.util.CSV.FormatInfo format) throws TupleException Set the field at a specified field name to a specified boxed value.See setField(Schema.Field, Object)for a discussion of possible conversions of the value.- Parameters:
- fieldPathName- the name of the field to set
- value- the value to set the field to. This can be null to set the field to null.
- format- the FormatInfo to use when parsing items, such as timestamp strings, in the value.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setFieldSet the field at a specified field index to a specified boxed value.See setField(Schema.Field, Object)for a discussion of possible conversions of the value.- Parameters:
- fieldIndex- the index of the field to set (starting at 0)
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setFieldSet a specified field to a specified boxed value.If the value is not a natural type for the type of the specified field, this method attempts to convert the value based on the field's type. (A "natural type" for a field type is the Java type that is acceptable to a type-specific setXxx() method for that field. In the list below, the natural types for each StreamBase type are listed in parentheses after each type.) Conversions: - int (Integer), double (Double), long (Long)
- Numeric value types are converted (possibly with loss of precision)
 if necessary. For all other values types, the value is converted
 to a String(withObject.toString()) and an attempt is made to parse the string into a numeric value of the required type.
- boolean (Boolean):
- The value is converted to a String, turned to lowercase, and then checked for the string values "true", "yes", "1", and "t" (all of which result in the field being set to true) and "false", "no", "0", and "f" (all of which result in the field being set to false).
- string (String):
- Values of type ByteArrayViewandbyte[]are assigned by converting the bytes to a string using an internal StreamBase conversion routine. For all other value types, the value is converted to aStringwithObject.toString().
- timestamp (Timestamp):
- Values of type Dateare converted withTimestamp(java.util.Date). Numeric value types are treated as a number of seconds (time interval).
- blob (byte[], ByteArrayView):
- If the value is a String, it's converted to an array of bytes, representing the ASCII encoding of the string's characters unless overridden by the setting of the streambase.tuple-charset Java property.
- tuple (Tuple):
- If the value is a String, it's parsed as a CSV-formatted list of field values (e.g., "1,foo").
- list (List):
- If the value is a String, it's parsed as a square-bracketed, CSV-formatted list of element values (e.g., "[1,3,5]").
 If a conversion is required but none of the above conversions apply, a TupleExceptionexception is thrownNote on CSV (comma-separated values) format: In the case of list or tuple fields which themselves contain list or tuple values, care must be taken to properly use double quotes where necessary. (The presence of commas in those nested values in the CSV string requires them to be surrounded by quotes. Further nesting may require increased quoting.) See RFC 4180 for details on CSV format. - Parameters:
- field- field to set
- value- the value to set the field to. This can be null to set the field to null.
- Throws:
- TupleException- if there was a value conversion error, the field doesn't exist in this Tuple or while traversing to a sub-field a null value was encountered
- Since:
- 6.0
 
- int (
- 
setFieldpublic final void setField(Schema.Field field, Object value, com.streambase.sb.util.CSV.FormatInfo format) throws TupleException Set the field at a specified field name to a specified boxed value.See setField(Schema.Field, Object)for a discussion of possible conversions of the value.- Parameters:
- field- field to set
- value- the value to set the field to. This can be null to set the field to null.
- format- the FormatInfo to use when parsing items, such as timestamp strings, in the value.
- Throws:
- TupleException- if there was a conversion error or if the field doesn't exist
 
- 
setNullSet a named field to null.- Parameters:
- fieldPathName- the path name of the field to get. See- getField(String)for notes on path segment syntax.
- Throws:
- TupleException- thrown when the Field cannot be found
 
- 
setNullpublic final void setNull(int fieldIndex) Set the field at a specified field index to null.- Parameters:
- fieldIndex- the index of the field to set to null (starting at 0)
 
- 
setNullSet the specified field to null- Parameters:
- field- the field to set to null
 
- 
toStringReturn a string representation of this Tuple. The delimiter is a comma and the quote character is a double quote.- Parameters:
- verbose- should field names and tuple id (if available) be included?
- Returns:
- a string representation of this Tuple
 
- 
toStringReturn a string representation of this Tuple.- Parameters:
- delimiter- the character to insert between each field
- quoteChar- the character used to surround string fields
- verbose- should field names and tuple id (if available) be included?
- Returns:
- a string representation of this Tuple
 
- 
toStringReturn a string representation of this Tuple.- Parameters:
- delimiter- the character to insert between each field
- quoteChar- the character used to surround string fields
- verbose- should field names be included?
- showTupleId- should the tuple id, if available, be shown?
- Returns:
- a string representation of this Tuple
 
- 
toStringReturn a string representation of this Tuple.- Parameters:
- delimiter- the character to insert between each field
- quoteChar- the character used to surround string fields
- verbose- should field names and tuple id (if available) be included?
- nullString- the string to use for null field values
- Returns:
- a string representation of this Tuple
 
- 
toStringpublic String toString(char delimiter, char quoteChar, boolean verbose, boolean showTupleId, String nullString) Return a string representation of this Tuple.- Parameters:
- delimiter- the character to insert between each field
- quoteChar- the character used to surround string fields
- verbose- should field names be included?
- showTupleId- should the tuple id, if available, be shown?
- nullString- the string to use for null field values
- Returns:
- a string representation of this Tuple
 
- 
equalsTest whether the given object is equal to this one. Tuples are considered equal if all of their fields are equal, and their schemas match exactly (including order of fields).
- 
hashCode
- 
toDelimitedStringReturn the tuple as a string delimited by the given character.- Parameters:
- delimiter- the delimiter
- Returns:
- the tuple as a string delimited by the given character.
 
- 
createWritableTupleReturn a new tuple that is guaranteed to be writable- Returns:
- a writable tuple
 
- 
createReadOnlyTupleReturn a new tuple that is guaranteed to be read only- Returns:
- a read only tuple
- Since:
- 7.0
 
- 
copyFieldpublic void copyField(Schema.Field sourceField, Tuple destTuple, Schema.Field destField) throws TupleException Copy the field from this tuple to the destination tuple- Parameters:
- sourceField- the source field
- destTuple- the destination tuple
- destField- the destination field
- Throws:
- TupleException- if type mismatch, missing fields
- Since:
- 6.4.5
 
- 
toMapViewReturns a view on this Tuple that implements the Map<String, Object> interface. Changes to this Tuple will be reflected in the returned Map<String, Object> and vice versa.The keys of this map are the field names of the schema of this tuple. The values of this map are the current values of this map. These values are the same as returned by getField(String).Map<String, Object>.get(Object key) will return a null for fields that are null and that do not exist in this Tuple. Use Map<String, Object>.containsKey(Object key) to determine if a key is a valid field in this Tuple. Repeated calls to toMapView()will return the same instance of Map<String, Object>.This Map<String, Object> does not support any remove operations. This Map is backed by a Tuple with a fixed schema. Any modify operations that attempt to address keys that are not in the fixed schema are not supported. - Returns:
- a Map<String, Object> view of this Tuple.
- Since:
- 7.0
 
- 
getTupleFormatterReturns a shared instance of the default tuple field formatter that converts each type to String using Java default String conversions. For string formatting rules used by each type, seeTuple.DefaultTupleFormatter.- Returns:
- a Tuple.TupleFormatterinstance suitable for use ingetFieldAsString(Schema.Field, TupleFormatter)
- Since:
- 7.0 method added, 7.1 tuples and lists recursively use the formatter for sub-fields and elements
 
- 
checkTypeAndNonNullprotected int checkTypeAndNonNull(Schema.Field resolvedField, DataType dataType) throws TupleException check the type and make sure it is non null- Parameters:
- resolvedField- resolved field
- dataType- data type
- Returns:
- field index or other information (depending upon overrides)
- Throws:
- TupleException- on error
 
- 
checkTypeCheck type- Parameters:
- resolvedField- Field
- dataType- Data type
- Throws:
- TupleException- Invalid type
 
- 
copyTuplecopy the source tuple to this tuple- Parameters:
- sourceTuple- source tuple to be copied
- Throws:
- TupleException- on error
 
 
- 
toMapView()