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
DEBUG_ENABLED, 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 java.lang.StringapplyLocks(java.lang.String sql, QueryParameters parameters, Dialect dialect, java.util.List<AfterLoadAction> afterLoadActions)Append FOR UPDATE OF clause, if necessary.protected voidautoDiscoverTypes(java.sql.ResultSet rs)protected intbindParameterValues(java.sql.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 java.lang.StringgetQueryIdentifier()Identifies the query for statistics reporting, if null, no statistics will be reportedjava.util.SetgetQuerySpaces()protected java.lang.ObjectgetResultColumnOrRow(java.lang.Object[] row, ResultTransformer transformer, java.sql.ResultSet rs, SharedSessionContractImplementor session)Get the actual object that is returned in the user-visible result list.protected java.util.ListgetResultList(java.util.List results, ResultTransformer resultTransformer)protected java.lang.Object[]getResultRow(java.lang.Object[] row, java.sql.ResultSet rs, SharedSessionContractImplementor session)protected java.lang.String[]getResultRowAliases()Returns the aliases that corresponding to a result row.java.lang.StringgetSQLString()The SQL query string to be called; implemented by all subclassesprotected boolean[]includeInResultRow()java.util.Listlist(SharedSessionContractImplementor session, QueryParameters queryParameters)protected voidputResultInQueryCache(SharedSessionContractImplementor session, QueryParameters queryParameters, Type[] resultTypes, QueryResultsCache queryCache, QueryKey key, java.util.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(java.lang.String alias)-
Methods inherited from class org.hibernate.loader.Loader
applyPostLoadLocks, areResultSetRowsTransformedImmediately, bindNamedParameters, bindPositionalParameters, checkScrollability, determineFollowOnLockMode, doList, doQueryAndInitializeNonLazyCollections, doQueryAndInitializeNonLazyCollections, executeQueryStatement, executeQueryStatement, extractKeysFromResultSet, getAliases, getCompositeKeyManyToOneTargetIndices, getEntityEagerPropertyFetches, getFactory, getLimitHandler, getNamedParameterLocs, getOwnerAssociationTypes, getResultSet, getResultSet, hasSubselectLoadableCollections, isSingleRowLoader, isSubselectLoadingEnabled, list, loadCollection, loadCollectionBatch, loadCollectionSubselect, loadEntity, loadEntity, loadEntityBatch, loadSequentialRowsForward, loadSequentialRowsReverse, loadSingleRow, needsFetchingScroll, postInstantiate, prepareQueryStatement, preprocessSQL, processDistinctKeyword, processResultSet, scroll, shouldUseFollowOnLocking, toString, upgradeLocks
-
-
-
-
Constructor Detail
-
CustomLoader
public CustomLoader(CustomQuery customQuery, SessionFactoryImplementor factory)
-
-
Method Detail
-
getQueryIdentifier
protected java.lang.String getQueryIdentifier()
Description copied from class:LoaderIdentifies the query for statistics reporting, if null, no statistics will be reported- Overrides:
getQueryIdentifierin classLoader
-
getSQLString
public java.lang.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 java.util.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 java.util.List list(SharedSessionContractImplementor session, QueryParameters queryParameters) throws HibernateException
- Throws:
HibernateException
-
applyLocks
protected java.lang.String applyLocks(java.lang.String sql, QueryParameters parameters, Dialect dialect, java.util.List<AfterLoadAction> afterLoadActions) throws QueryExceptionDescription 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 java.lang.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 java.lang.Object getResultColumnOrRow(java.lang.Object[] row, ResultTransformer transformer, java.sql.ResultSet rs, SharedSessionContractImplementor session) throws java.sql.SQLException, HibernateExceptionDescription 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:
java.sql.SQLExceptionHibernateException
-
getResultRow
protected java.lang.Object[] getResultRow(java.lang.Object[] row, java.sql.ResultSet rs, SharedSessionContractImplementor session) throws java.sql.SQLException, HibernateException- Overrides:
getResultRowin classLoader- Throws:
java.sql.SQLExceptionHibernateException
-
getResultList
protected java.util.List getResultList(java.util.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(java.sql.PreparedStatement statement, QueryParameters queryParameters, int startIndex, SharedSessionContractImplementor session) throws java.sql.SQLExceptionDescription 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:
java.sql.SQLException- Indicates problems performing the binding.
-
autoDiscoverTypes
protected void autoDiscoverTypes(java.sql.ResultSet rs)
- Overrides:
autoDiscoverTypesin classLoader
-
validateAlias
protected void validateAlias(java.lang.String alias)
-
putResultInQueryCache
protected void putResultInQueryCache(SharedSessionContractImplementor session, QueryParameters queryParameters, Type[] resultTypes, QueryResultsCache queryCache, QueryKey key, java.util.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, overriden here to provide theresultTypes. see HHH-3051- Overrides:
putResultInQueryCachein classLoader
-
-