Package org.jdbi.v3.core.statement
Class StatementContext
java.lang.Object
org.jdbi.v3.core.statement.StatementContext
- All Implemented Interfaces:
- Closeable,- AutoCloseable
The statement context provides access to statement-local configuration.
 Context is inherited from the parent 
Handle initially and changes will
 not outlive the statement.
 The context will be passed through most major jdbi APIs.
 DISCLAIMER: The class is not intended to be extended. The final modifier is absent to allow mock tools to create a mock object of this class in the user code.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddCleanable(Cleanable cleanable) Registers aCleanableto be invoked when the statement context is closed.voidclose()voidDefine an attribute for in this context.Returns the type of the statement that owns this statement context as a descriptive string.findArgumentFor(Type type, Object value) Obtain an argument for given value in this contextfindArgumentFor(QualifiedType<?> type, Object value) Obtain an argument for given value in this contextfindCollectorFor(Type containerType) Obtain a collector for the given type.<T> Optional<ColumnMapper<T>> findColumnMapperFor(Class<T> type) Obtain a column mapper for the given type in this context.Optional<ColumnMapper<?>> findColumnMapperFor(Type type) Obtain a column mapper for the given type in this context.<T> Optional<ColumnMapper<T>> findColumnMapperFor(GenericType<T> type) Obtain a column mapper for the given type in this context.<T> Optional<ColumnMapper<T>> findColumnMapperFor(QualifiedType<T> type) Obtain a column mapper for the given qualified type in this context.findElementTypeFor(Type containerType) Returns the element type for the given container type.findMapperFor(Class<T> type) Obtain a mapper for the given type in this context.findMapperFor(Type type) Obtain a mapper for the given type in this context.findMapperFor(GenericType<T> type) Obtain a mapper for the given type in this context.findMapperFor(QualifiedType<T> type) Obtain a mapper for the given qualified type in this context.findRowMapperFor(Class<T> type) Obtain a row mapper for the given type in this context.findRowMapperFor(Type type) Obtain a row mapper for the given type in this context.findRowMapperFor(GenericType<T> type) Obtain a row mapper for the given type in this context.Optional<SqlArrayType<?>> findSqlArrayTypeFor(Type elementType) Obtain anSqlArrayTypefor the given array element type in this contextgetAttribute(String key) Obtain the value of an attributeReturns the attributes applied in this context.Returns the statement binding.If query execution was successful, returns the query execution end as anInstant.Returns theConfigRegistry.<C extends JdbiConfig<C>>
 CGets the configuration object of the given type, associated with this context.Obtain the JDBC connection being used for this statementlonggetElapsedTime(ChronoUnit unit) Convenience method to measure elapsed time between start of query execution and completion or exception as appropriate.If query execution failed, returns the query execution end as anInstant.Returns the query execution start as anInstant.String[]Returns the generated key column names or empty if none were generated.Inspect the type of the statement that owns this statement context.longRetrieve the number of mapped rows.Obtain the parsed SQL statementObtain the initial sql for the statement used to create the statementObtain the rendered SQL statementReturns the strategy used by this context to bind array-type arguments to SQL statements.Obtain the actual prepared statement being used.Instrument the telemetry trace id.booleanReturn if the statement should be concurrent updatable.booleanWhether the statement being generated is expected to return generated keys.voidsetCompletionMoment(Instant completionMoment) Sets the query execution end.voidsetConcurrentUpdatable(boolean concurrentUpdatable) Set the context to create a concurrent updatable result set.voidsetExceptionMoment(Instant exceptionMoment) Sets the query execution end.voidsetExecutionMoment(Instant executionMoment) Sets the query execution start.voidsetGeneratedKeysColumnNames(String[] generatedKeysColumnNames) Set the generated key column names.voidsetMappedRows(long mappedRows) Instrument the number of mapped rows.voidsetReturningGeneratedKeys(boolean returningGeneratedKeys) Sets whether the current statement returns generated keys.voidsetTraceId(String traceId) Instrument the telemetry trace id.
- 
Method Details- 
getJdbiStatementTypeInspect the type of the statement that owns this statement context.
- 
describeJdbiStatementTypeReturns the type of the statement that owns this statement context as a descriptive string.- Returns:
- the type of the statement that owns this statement context as a descriptive string
 
- 
getConfigGets the configuration object of the given type, associated with this context.- Type Parameters:
- C- the configuration type
- Parameters:
- configClass- the configuration type
- Returns:
- the configuration object of the given type, associated with this context.
 
- 
getConfigReturns theConfigRegistry.- Returns:
- the ConfigRegistryused by this context.
 
- 
getAttributesReturns the attributes applied in this context.- Returns:
- the defined attributes.
 
- 
getAttributeObtain the value of an attribute- Parameters:
- key- the name of the attribute
- Returns:
- the value of the attribute
 
- 
defineDefine an attribute for in this context.- Parameters:
- key- the key for the attribute
- value- the value for the attribute
 
- 
findArgumentForObtain an argument for given value in this context- Parameters:
- type- the type of the argument.
- value- the argument value.
- Returns:
- an Argument for the given value.
 
- 
findArgumentForObtain an argument for given value in this context- Parameters:
- type- the type of the argument.
- value- the argument value.
- Returns:
- an Argument for the given value.
 
- 
getSqlArrayArgumentStrategyReturns the strategy used by this context to bind array-type arguments to SQL statements.- Returns:
- the strategy used to bind array-type arguments to SQL statements
 
- 
findSqlArrayTypeForObtain anSqlArrayTypefor the given array element type in this context- Parameters:
- elementType- the array element type.
- Returns:
- an SqlArrayTypefor the given element type.
 
- 
findMapperForObtain a mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a mapper for the given type, or empty if no row or column mappers is registered for the given type.
 
- 
findMapperForObtain a mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a mapper for the given type, or empty if no row or column mappers is registered for the given type.
 
- 
findMapperForObtain a mapper for the given type in this context.- Parameters:
- type- the target type to map to
- Returns:
- a mapper for the given type, or empty if no row or column mappers is registered for the given type.
 
- 
findMapperForObtain a mapper for the given qualified type in this context.- Parameters:
- type- the target qualified type to map to
- Returns:
- a mapper for the given qualified type, or empty if no row or column mappers is registered for the given type.
 
- 
findColumnMapperForObtain a column mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a ColumnMapper for the given type, or empty if no column mapper is registered for the given type.
 
- 
findColumnMapperForObtain a column mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a ColumnMapper for the given type, or empty if no column mapper is registered for the given type.
 
- 
findColumnMapperForObtain a column mapper for the given type in this context.- Parameters:
- type- the target type to map to
- Returns:
- a ColumnMapper for the given type, or empty if no column mapper is registered for the given type.
 
- 
findColumnMapperForObtain a column mapper for the given qualified type in this context.- Parameters:
- type- the qualified target type to map to
- Returns:
- a ColumnMapper for the given type, or empty if no column mapper is registered for the given type.
 
- 
findRowMapperForObtain a row mapper for the given type in this context.- Parameters:
- type- the target type to map to
- Returns:
- a RowMapper for the given type, or empty if no row mapper is registered for the given type.
 
- 
findRowMapperForObtain a row mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a RowMapper for the given type, or empty if no row mapper is registered for the given type.
 
- 
findRowMapperForObtain a row mapper for the given type in this context.- Type Parameters:
- T- the type to map
- Parameters:
- type- the target type to map to
- Returns:
- a RowMapper for the given type, or empty if no row mapper is registered for the given type.
 
- 
findCollectorForObtain a collector for the given type.- Parameters:
- containerType- the container type.
- Returns:
- a Collector for the given container type, or empty null if no collector is registered for the given type.
 
- 
findElementTypeForReturns the element type for the given container type.- Parameters:
- containerType- the container type.
- Returns:
- the element type for the given container type, if available.
 
- 
getRawSqlObtain the initial sql for the statement used to create the statement- Returns:
- the initial sql
 
- 
getRenderedSqlObtain the rendered SQL statementNot available until until statement execution time - Returns:
- the sql statement after processing template directives.
 
- 
getParsedSqlObtain the parsed SQL statementNot available until until statement execution time - Returns:
- the sql statement as it will be executed against the database
 
- 
getStatementObtain the actual prepared statement being used.Not available until execution time - Returns:
- Obtain the actual prepared statement being used.
 
- 
getConnectionObtain the JDBC connection being used for this statement- Returns:
- the JDBC connection
 
- 
getBindingReturns the statement binding.- Returns:
- The statement binding.
 
- 
setReturningGeneratedKeyspublic void setReturningGeneratedKeys(boolean returningGeneratedKeys) Sets whether the current statement returns generated keys.- Parameters:
- returningGeneratedKeys- return generated keys?
 
- 
isReturningGeneratedKeyspublic boolean isReturningGeneratedKeys()Whether the statement being generated is expected to return generated keys.- Returns:
- whether the statement being generated is expected to return generated keys.
 
- 
getGeneratedKeysColumnNamesReturns the generated key column names or empty if none were generated.- Returns:
- the generated key column names. Returns an empty array if none exist.
 
- 
setGeneratedKeysColumnNamesSet the generated key column names.- Parameters:
- generatedKeysColumnNames- the generated key column names
 
- 
isConcurrentUpdatablepublic boolean isConcurrentUpdatable()Return if the statement should be concurrent updatable. If this returns true, the concurrency level of the created ResultSet will beResultSet.CONCUR_UPDATABLE, otherwise the result set is not updatable, and will have concurrency levelResultSet.CONCUR_READ_ONLY.- Returns:
- if the statement generated should be concurrent updatable.
 
- 
setConcurrentUpdatablepublic void setConcurrentUpdatable(boolean concurrentUpdatable) Set the context to create a concurrent updatable result set. This cannot be combined withisReturningGeneratedKeys(), only one option may be selected. It does not make sense to combine these either, as one applies to queries, and the other applies to updates.- Parameters:
- concurrentUpdatable- if the result set should be concurrent updatable.
 
- 
getExecutionMomentReturns the query execution start as anInstant.- Returns:
- the Instantat which query execution began
 
- 
setExecutionMomentSets the query execution start. This is not part of the Jdbi API and should not be called by code outside JDBI.- Parameters:
- executionMoment- Sets the start of query execution.
 
- 
getCompletionMomentIf query execution was successful, returns the query execution end as anInstant.- Returns:
- the Instantat which query execution ended, if it did so successfully
 
- 
setCompletionMomentSets the query execution end. This is not part of the Jdbi API and should not be called by code outside JDBI.- Parameters:
- completionMoment- Sets the end of query execution.
 
- 
getExceptionMomentIf query execution failed, returns the query execution end as anInstant.- Returns:
- the Instantat which query execution ended, if it did so with an exception
 
- 
setExceptionMomentSets the query execution end. This is not part of the Jdbi API and should not be called by code outside JDBI.- Parameters:
- exceptionMoment- Sets the end of query execution.
 
- 
getMappedRowsRetrieve the number of mapped rows. Only intended for internal instrumentation to call.
- 
setMappedRowsInstrument the number of mapped rows. Only intended for internal instrumentation to call.
- 
setTraceIdInstrument the telemetry trace id. Only intended for internal instrumentation to call.
- 
getTraceIdInstrument the telemetry trace id. Only intended for internal instrumentation to call.
- 
getElapsedTimeConvenience method to measure elapsed time between start of query execution and completion or exception as appropriate. Do not call with a null argument or before a query has executed/exploded.- Parameters:
- unit- the time unit to convert to
- Returns:
- the elapsed time in the given unit
 
- 
addCleanableRegisters aCleanableto be invoked when the statement context is closed. Cleanables can be registered on a statement context, which will be cleaned up when the statement finishes or (in the case of a ResultIterator), the object representing the results is closed.Resources cleaned up by Jdbi include ResultSet,Statement,Handle,Array, andStatementBuilder.- Parameters:
- cleanable- the Cleanable to clean on close
 
- 
closepublic void close()- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
 
- 
getExtensionMethod
 
-