Package org.hibernate.loader.custom
Class CustomLoader
- java.lang.Object
-
- org.hibernate.loader.Loader
-
- org.hibernate.loader.custom.CustomLoader
-
public class CustomLoader extends Loader
Extension point for loaders which use a SQL result set with "unexpected" column aliases.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.hibernate.loader.Loader
Loader.SqlStatementWrapper
-
-
Field Summary
-
Fields inherited from class org.hibernate.loader.Loader
LOG, SELECT, SELECT_DISTINCT
-
-
Constructor Summary
Constructors Constructor Description CustomLoader(CustomQuery customQuery, SessionFactoryImplementor factory)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected StringapplyLocks(String sql, QueryParameters parameters, Dialect dialect, List<AfterLoadAction> afterLoadActions)Append FOR UPDATE OF clause, if necessary.protected voidautoDiscoverTypes(ResultSet rs)protected intbindParameterValues(PreparedStatement statement, QueryParameters queryParameters, int startIndex, SharedSessionContractImplementor session)Bind all parameter values into the prepared statement in preparation for execution.protected CollectionAliases[]getCollectionAliases()protected int[]getCollectionOwners()Get the index of the entity that owns the collection, or -1 if there is no owner in the query results (ie.protected CollectionPersister[]getCollectionPersisters()An (optional) persister for a collection to be initialized; only collection loaders return a non-null valueprotected EntityAliases[]getEntityAliases()Get the result set descriptorprotected Loadable[]getEntityPersisters()An array of persisters of entity classes contained in each row of results; implemented by all subclassesprotected LockMode[]getLockModes(LockOptions lockOptions)What lock options does this load entities with?protected int[]getOwners()An array of indexes of the entity that owns a one-to-one association to the entity at the given index (-1 if there is no "owner").protected StringgetQueryIdentifier()Identifies the query for statistics reporting, if null, no statistics will be reportedSetgetQuerySpaces()protected ObjectgetResultColumnOrRow(Object[] row, ResultTransformer transformer, ResultSet rs, SharedSessionContractImplementor session)Get the actual object that is returned in the user-visible result list.protected ListgetResultList(List results, ResultTransformer resultTransformer)protected Object[]getResultRow(Object[] row, ResultSet rs, SharedSessionContractImplementor session)protected String[]getResultRowAliases()Returns the aliases that corresponding to a result row.StringgetSQLString()The SQL query string to be called; implemented by all subclassesprotected boolean[]includeInResultRow()Listlist(SharedSessionContractImplementor session, QueryParameters queryParameters)protected voidputResultInQueryCache(SharedSessionContractImplementor session, QueryParameters queryParameters, Type[] resultTypes, QueryResultsCache queryCache, QueryKey key, List result)resultTypescan be overridden byautoDiscoverTypes(ResultSet), *after*list(SharedSessionContractImplementor, QueryParameters)has already been called.protected ResultTransformerresolveResultTransformer(ResultTransformer resultTransformer)Determine the actual ResultTransformer that will be used to transform query results.ScrollableResultsImplementorscroll(QueryParameters queryParameters, SharedSessionContractImplementor session)protected voidvalidateAlias(String alias)-
Methods inherited from class org.hibernate.loader.Loader
applyPostLoadLocks, areResultSetRowsTransformedImmediately, bindNamedParameters, bindPositionalParameters, bindPreparedStatement, checkScrollability, createCacheableResultTransformer, createSubselects, determineFollowOnLockMode, doList, doQueryAndInitializeNonLazyCollections, doQueryAndInitializeNonLazyCollections, endCollectionLoad, executeQueryStatement, executeQueryStatement, extractKeysFromResultSet, generateQueryKey, getAliases, getCompositeKeyManyToOneTargetIndices, getEntityEagerPerPropertyFetches, getEntityEagerPropertyFetches, getEntityPersister, getFactory, getLimitHandler, getNamedParameterLocs, getOptionalObjectKey, getOwnerAssociationTypes, getResultFromQueryCache, getResultSet, getResultSet, getRowsFromResultSet, handleEmptyCollections, hasSubselectLoadableCollections, instanceAlreadyLoaded, instanceNotYetLoaded, isSingleRowLoader, isSubselectLoadingEnabled, list, loadCollection, loadCollectionBatch, loadCollectionSubselect, loadEntity, loadEntity, loadEntityBatch, loadEntityBatch, loadSequentialRowsForward, loadSequentialRowsReverse, loadSingleRow, needsFetchingScroll, postInstantiate, prepareQueryStatement, preprocessResultSet, preprocessSQL, processDistinctKeyword, processResultSet, registerNonExists, scroll, shouldUseFollowOnLocking, toString, upgradeLocks
-
-
-
-
Constructor Detail
-
CustomLoader
public CustomLoader(CustomQuery customQuery, SessionFactoryImplementor factory)
-
-
Method Detail
-
getQueryIdentifier
protected String getQueryIdentifier()
Description copied from class:LoaderIdentifies the query for statistics reporting, if null, no statistics will be reported- Overrides:
getQueryIdentifierin classLoader
-
getSQLString
public String getSQLString()
Description copied from class:LoaderThe SQL query string to be called; implemented by all subclasses- Specified by:
getSQLStringin classLoader- Returns:
- The sql command this loader should use to get its
ResultSet.
-
getQuerySpaces
public Set getQuerySpaces()
-
getLockModes
protected LockMode[] getLockModes(LockOptions lockOptions)
Description copied from class:LoaderWhat lock options does this load entities with?- Specified by:
getLockModesin classLoader- Parameters:
lockOptions- a collection of lock options specified dynamically via the Query interface
-
getEntityPersisters
protected Loadable[] getEntityPersisters()
Description copied from class:LoaderAn array of persisters of entity classes contained in each row of results; implemented by all subclasses- Specified by:
getEntityPersistersin classLoader- Returns:
- The entity persisters.
-
getCollectionPersisters
protected CollectionPersister[] getCollectionPersisters()
Description copied from class:LoaderAn (optional) persister for a collection to be initialized; only collection loaders return a non-null value- Overrides:
getCollectionPersistersin classLoader
-
getCollectionOwners
protected int[] getCollectionOwners()
Description copied from class:LoaderGet the index of the entity that owns the collection, or -1 if there is no owner in the query results (ie. in the case of a collection initializer) or no collection.- Overrides:
getCollectionOwnersin classLoader
-
getOwners
protected int[] getOwners()
Description copied from class:LoaderAn array of indexes of the entity that owns a one-to-one association to the entity at the given index (-1 if there is no "owner"). The indexes contained here are relative to the result ofLoader.getEntityPersisters().
-
list
public List list(SharedSessionContractImplementor session, QueryParameters queryParameters) throws HibernateException
- Throws:
HibernateException
-
applyLocks
protected String applyLocks(String sql, QueryParameters parameters, Dialect dialect, List<AfterLoadAction> afterLoadActions) throws QueryException
Description copied from class:LoaderAppend FOR UPDATE OF clause, if necessary. This empty superclass implementation merely returns its first argument.- Overrides:
applyLocksin classLoader- Throws:
QueryException
-
scroll
public ScrollableResultsImplementor scroll(QueryParameters queryParameters, SharedSessionContractImplementor session) throws HibernateException
- Throws:
HibernateException
-
getResultRowAliases
protected String[] getResultRowAliases()
Description copied from class:LoaderReturns the aliases that corresponding to a result row.- Overrides:
getResultRowAliasesin classLoader- Returns:
- Returns the aliases that corresponding to a result row.
-
resolveResultTransformer
protected ResultTransformer resolveResultTransformer(ResultTransformer resultTransformer)
Description copied from class:LoaderDetermine the actual ResultTransformer that will be used to transform query results.- Overrides:
resolveResultTransformerin classLoader- Parameters:
resultTransformer- the specified result transformer- Returns:
- the actual result transformer
-
includeInResultRow
protected boolean[] includeInResultRow()
- Overrides:
includeInResultRowin classLoader
-
getResultColumnOrRow
protected Object getResultColumnOrRow(Object[] row, ResultTransformer transformer, ResultSet rs, SharedSessionContractImplementor session) throws SQLException, HibernateException
Description copied from class:LoaderGet the actual object that is returned in the user-visible result list. This empty implementation merely returns its first argument. This is overridden by some subclasses.- Overrides:
getResultColumnOrRowin classLoader- Throws:
SQLExceptionHibernateException
-
getResultRow
protected Object[] getResultRow(Object[] row, ResultSet rs, SharedSessionContractImplementor session) throws SQLException, HibernateException
- Overrides:
getResultRowin classLoader- Throws:
SQLExceptionHibernateException
-
getResultList
protected List getResultList(List results, ResultTransformer resultTransformer) throws QueryException
- Overrides:
getResultListin classLoader- Throws:
QueryException
-
getEntityAliases
protected EntityAliases[] getEntityAliases()
Description copied from class:LoaderGet the result set descriptor- Specified by:
getEntityAliasesin classLoader
-
getCollectionAliases
protected CollectionAliases[] getCollectionAliases()
- Specified by:
getCollectionAliasesin classLoader
-
bindParameterValues
protected int bindParameterValues(PreparedStatement statement, QueryParameters queryParameters, int startIndex, SharedSessionContractImplementor session) throws SQLException
Description copied from class:LoaderBind all parameter values into the prepared statement in preparation for execution.- Overrides:
bindParameterValuesin classLoader- Parameters:
statement- The JDBC prepared statementqueryParameters- The encapsulation of the parameter values to be bound.startIndex- The position from which to start binding parameter values.session- The originating session.- Returns:
- The number of JDBC bind positions actually bound during this method execution.
- Throws:
SQLException- Indicates problems performing the binding.
-
autoDiscoverTypes
protected void autoDiscoverTypes(ResultSet rs)
- Overrides:
autoDiscoverTypesin classLoader
-
validateAlias
protected void validateAlias(String alias)
-
putResultInQueryCache
protected void putResultInQueryCache(SharedSessionContractImplementor session, QueryParameters queryParameters, Type[] resultTypes, QueryResultsCache queryCache, QueryKey key, List result)
resultTypescan be overridden byautoDiscoverTypes(ResultSet), *after*list(SharedSessionContractImplementor, QueryParameters)has already been called. It's a bit of a chicken-and-the-egg issue sinceautoDiscoverTypes(ResultSet)needs theResultSet. As a hacky workaround, overridden here to provide theresultTypes. see HHH-3051- Overrides:
putResultInQueryCachein classLoader
-
-