Class DurationJavaType
- All Implemented Interfaces:
Serializable, BasicJavaType<Duration>, JavaType<Duration>
Duration, which is represented internally
as (long seconds, int nanoseconds), approximately
28 decimal digits of precision. This quantity must be stored in
the database as a single integer with units of nanoseconds, unless
the ANSI SQL interval type is supported.
In practice, the 19 decimal digits of a SQL bigint are
capable of representing six centuries in nanoseconds and are
sufficient for many applications. However, by default, we map
Java Duration to SQL numeric(21) here, which
can comfortably represent 60 millennia of nanos.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface JavaType
JavaType.CoercionContext -
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfromString(CharSequence string) intgetDefaultSqlPrecision(Dialect dialect, JdbcType jdbcType) The default column precision when this Java type is mapped to a SQL data type which is parametrized by precision, for exampleTypes.DECIMAL.intgetDefaultSqlScale(Dialect dialect, JdbcType jdbcType) The default column scale when this Java type is mapped to a SQL data type which is parametrized by scale, for exampleTypes.DECIMAL.getRecommendedJdbcType(JdbcTypeIndicators context) Obtain the "recommended" SQL type descriptor for this Java type.booleanisInstance(Object value) Is the given value an instance of the described type?<X> Xunwrap(Duration duration, Class<X> type, WrapperOptions options) Unwrap an instance of our handled Java type into the requested type.booleanWhether to useObject.equals(Object)andObject.hashCode()orJavaType.areEqual(Object, Object)andJavaType.extractHashCode(Object)for objects of this java type.<X> Durationwrap(X value, WrapperOptions options) Wrap a value as our handled Java type.Methods inherited from class AbstractClassJavaType
areEqual, extractHashCode, extractLoggableRepresentation, getComparator, getJavaType, getJavaTypeClass, getMutabilityPlan, unknownUnwrap, unknownWrapMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface JavaType
appendEncodedString, coerce, createJavaType, fromEncodedString, fromEncodedString, getCheckCondition, getDefaultSqlLength, getDefaultValue, getLongSqlLength, getReplacement, getTypeName, isTemporalType, isWider
-
Field Details
-
INSTANCE
Singleton access
-
-
Constructor Details
-
DurationJavaType
public DurationJavaType()
-
-
Method Details
-
isInstance
Description copied from interface:JavaTypeIs the given value an instance of the described type?Usually just
getJavaTypeClass().isInstance(value), but some descriptors need specialized semantics, for example, the descriptors forjava.sql.Date,java.sql.Time, andjava.sql.Timestamp.For
EntityJavaType, this method handles proxies in a semantically correct way, by checking the entity instance underlying the proxy object. -
cast
Description copied from interface:JavaTypeApply a simple type cast to the given value, without attempting any sort of coercion or wrapping. This method is provided as a convenient way to avoid an unchecked cast to a type variable. UsejavaType.cast(value)instead of(T) valuewherever possible.Usually just
getJavaTypeClass().cast(value), but overridden in some cases as an "optimization". This optimization is almost certainly unnecessary, and might even indeed be harmful, sinceClass.cast()is an intrinsic. -
getRecommendedJdbcType
Description copied from interface:BasicJavaTypeObtain the "recommended" SQL type descriptor for this Java type. Often, but not always, the source of this recommendation is the JDBC specification.- Parameters:
context- Contextual information- Returns:
- The recommended SQL type descriptor
-
useObjectEqualsHashCode
public boolean useObjectEqualsHashCode()Description copied from interface:JavaTypeWhether to useObject.equals(Object)andObject.hashCode()orJavaType.areEqual(Object, Object)andJavaType.extractHashCode(Object)for objects of this java type. This is useful to avoid mega-morphic callsites. -
toString
-
fromString
-
unwrap
Description copied from interface:JavaTypeUnwrap an instance of our handled Java type into the requested type.As an example, if this is a
JavaType<Integer>and we are asked to unwrap theInteger valueas aLong, we would return something likeLong.valueOf( value.longValue() ).Intended use is during
PreparedStatementbinding.- Type Parameters:
X- The conversion type.- Parameters:
duration- The value to unwraptype- The type as which to unwrapoptions- The options- Returns:
- The unwrapped value.
-
wrap
-
getDefaultSqlPrecision
Description copied from interface:JavaTypeThe default column precision when this Java type is mapped to a SQL data type which is parametrized by precision, for exampleTypes.DECIMAL.- Returns:
Size.DEFAULT_PRECISIONunless overridden
-
getDefaultSqlScale
Description copied from interface:JavaTypeThe default column scale when this Java type is mapped to a SQL data type which is parametrized by scale, for exampleTypes.DECIMAL.- Returns:
Size.DEFAULT_SCALEunless overridden
-