- All Superinterfaces:
OptionalValue<Object>,Value<Object>
- All Known Implementing Classes:
DbColumnBase,MongoDbColumn
Column may represent a null value. Get methods on this class would throw an exception if the
value is null, use Value.asOptional(), or one of the mapping methods that support optional values, such as
OptionalValue.ifPresent(java.util.function.Consumer) to consume such columns.
-
Method Summary
Modifier and TypeMethodDescriptiondbType()Type of the column in the language of the database.default Objectget()Untyped value of this column, returns java type as provided by the underlying database driver.<T> Tget(GenericType<T> type) Value of this column as a generic type.<T> TTyped value of this column.Class<?> javaType()Type of the column as would be returned by the underlying database driver.name()Column name.Precision of this column.scale()Scale of this column.Methods inherited from interface io.helidon.common.mapper.OptionalValue
as, as, as, asBoolean, asDouble, asInt, asLong, asString, ifPresent, ifPresentOrElse, isEmpty, isPresent, map, or, orElse, orElseGet, orElseThrow, orElseThrowMethods inherited from interface io.helidon.common.mapper.Value
asOptional, filter, flatMap, getBoolean, getDouble, getInt, getLong, getString, stream
-
Method Details
-
get
Typed value of this column. This method can return a correct result only if the type is the same asjavaType()or there is aMapperregistered that can map it.- Specified by:
getin interfaceValue<Object>- Type Parameters:
T- type of the returned value- Parameters:
type- class of the type that should be returned (must be supported by the underlying data type)- Returns:
- value of this column correctly typed
- Throws:
MapperException- in case the type is not the underlyingjavaType()and there is no mapper registered for it
-
get
Value of this column as a generic type. This method can return a correct result only if the type represents a class, or if there is aMapperregistered that can map underlyingjavaType()to the type requested.- Specified by:
getin interfaceValue<Object>- Type Parameters:
T- type of the returned value- Parameters:
type- requested type- Returns:
- value mapped to the expected type if possible
- Throws:
MapperException- in case the mapping cannot be done
-
get
Untyped value of this column, returns java type as provided by the underlying database driver.WARNING: for backward compatibility, this method MAY return
nullif the underlying column value is null. As this is not aligned with Helidon APIs, which forbid returns ofnull, this will change in future versions. If you need support fornullablecolumns, use the optional-like methods on this type, such asOptionalValue.isEmpty(),OptionalValue.isPresent(),OptionalValue.ifPresent(java.util.function.Consumer)etc. to handle {code null} values. -
javaType
Class<?> javaType()Type of the column as would be returned by the underlying database driver.- Returns:
- class of the type
- See Also:
-
dbType
String dbType()Type of the column in the language of the database.Example for SQL - if a column is declared as
VARCHAR(256)in the database, this method would returnVARCHARand methodjavaType()would returnString.- Returns:
- column type as the database understands it
-
name
String name()Column name. -
precision
Precision of this column.Precision depends on data type:
- Numeric: The maximal number of digits of the number
- String/Character: The maximal length
- Binary: The maximal number of bytes
- Other: Implementation specific
- Returns:
- precision of this column or
emptyif precision is not available
-
scale
Scale of this column.Scale is the number of digits in a decimal number to the right of the decimal separator.
- Returns:
- scale of this column or
emptyif scale is not available
-