Class SQLSelect<T>
- All Implemented Interfaces:
- Serializable,- Query,- Select<T>
- Since:
- 4.0
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Stringprotected QueryCacheStrategyprotected CapsStrategyprotected Stringprotected intprotected intprotected intprotected PrefetchTreeNodeprotected intprotected StringBuilderprotected intFields inherited from class org.apache.cayenne.query.IndirectQuerydataMap, lastResolver, name, replacementQuery
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionaddPrefetch(String path, int semantics) Merges a prefetch path with specified semantics into the query prefetch tree.addPrefetch(PrefetchTreeNode node) Merges a prefetch into the query prefetch tree.Appends a piece of SQL to the previously stored SQL template.batchIterator(ObjectContext context, int size) Creates a ResultBatchIterator based on the provided context and batch size.cacheGroup(String cacheGroup) cacheStrategy(QueryCacheStrategy strategy) cacheStrategy(QueryCacheStrategy strategy, String cacheGroup) columnNameCaps(CapsStrategy columnNameCaps) Sets a column name capitalization policy applied to selecting queries.columnQuery(String sql) Creates query that selects scalar values (as Object[]) and uses default routingcolumnQuery(String sql, Class<?>... types) Creates query that selects scalar values (as Object[]) and uses default routingcolumnQuery(String sql, String dataMapName) Creates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.columnQuery(String sql, String dataMapName, Class<?>... types) Creates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.protected QuerycreateReplacementQuery(EntityResolver resolver) Creates a substitute query.dataRowQuery(String sql) Creates a query that selects DataRows and uses default routing.dataRowQuery(String sql, Class<?>... types) Creates a query that selects DataRows and uses default routing.dataRowQuery(String dataMapName, String sql) Creates a query that selects DataRows and uses routing based on the provided DataMap name.dataRowQuery(String dataMapName, String sql, Class<?>... types) Creates a query that selects DataRows and uses routing based on the provided DataMap name.Returns a column name capitalization policy applied to selecting queries.intgetLimit()intintReturns a potentially immmutable map of named parameters that will be bound to SQL.Returns a potentially immmutable list of positional parameters that will be bound to SQL.intgetSql()intbooleanvoiditerate(ObjectContext context, ResultIteratorCallback<T> callback) Creates a ResultIterator based on the provided context and passes it to a callback for processing.iterator(ObjectContext context) Creates a ResultIterator based on the provided context.limit(int fetchLimit) Instructs Cayenne to look for query results in the "local" cache when running the query.localCache(String cacheGroup) Instructs Cayenne to look for query results in the "local" cache when running the query.Equivalent of settingCapsStrategy.LOWER<E> SQLSelect<E> Map result of this query by processing with a given function.offset(int fetchOffset) pageSize(int pageSize) Deprecated.paramsArray(Object... params) Initializes positional parameters of the query.paramsList(List<Object> params) Initializes positional parameters of the query.static <T> SQLSelect<T> Creates a query that selects DataObjects.queryTimeout(int queryTimeout) Sets query timeoutstatic <T> SQLSelect<T> scalarQuery(Class<T> type, String sql) Deprecated.since 4.2.static <T> SQLSelect<T> scalarQuery(Class<T> type, String dataMapName, String sql) Deprecated.since 4.2.scalarQuery(String sql) Deprecated.since 4.2.scalarQuery(String sql, Class<?>... types) Deprecated.since 4.2.static <T> SQLSelect<T> scalarQuery(String sql, Class<T> type) Creates query that selects scalar value and uses default routingscalarQuery(String sql, String dataMapName) Deprecated.since 4.2.scalarQuery(String sql, String dataMapName, Class<?>... types) Deprecated.since 4.2.static <T> SQLSelect<T> scalarQuery(String sql, String dataMapName, Class<T> type) Creates query that selects scalar value and uses default routingselect(ObjectContext context) Selects objects using provided context.selectFirst(ObjectContext context) Selects a single object using provided context.selectOne(ObjectContext context) Selects a single object using provided context.Instructs Cayenne to look for query results in the "shared" cache when running the query.sharedCache(String cacheGroup) Instructs Cayenne to look for query results in the "shared" cache when running the query.statementFetchSize(int size) Sets JDBC statement's fetch size (0 for no default size)Equivalent of settingCapsStrategy.UPPERMethods inherited from class org.apache.cayenne.query.IndirectQuerycreateSQLAction, getMetaData, getReplacementQuery, routeMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.cayenne.query.QuerycreateSQLAction, getMetaData, route
- 
Field Details- 
persistentType
- 
dataMapName
- 
sqlBuffer
- 
cacheStrategy
- 
cacheGroup
- 
params
- 
positionalParams
- 
columnNameCaps
- 
limitprotected int limit
- 
offsetprotected int offset
- 
pageSizeprotected int pageSize
- 
statementFetchSizeprotected int statementFetchSize
- 
queryTimeoutprotected int queryTimeout
- 
prefetches
 
- 
- 
Constructor Details- 
SQLSelect
- 
SQLSelect
 
- 
- 
Method Details- 
dataRowQueryCreates a query that selects DataRows and uses default routing.
- 
dataRowQueryCreates a query that selects DataRows and uses default routing.- Since:
- 4.1
 
- 
dataRowQueryCreates a query that selects DataRows and uses routing based on the provided DataMap name.- Since:
- 4.1
 
- 
dataRowQueryCreates a query that selects DataRows and uses routing based on the provided DataMap name.
- 
queryCreates a query that selects DataObjects.
- 
scalarQueryDeprecated.since 4.2. UsescalarQuery(String, Class)method.Creates a query that selects scalar values and uses default routing.
- 
scalarQuery@Deprecated public static <T> SQLSelect<T> scalarQuery(Class<T> type, String dataMapName, String sql) Deprecated.since 4.2. UsescalarQuery(String, String, Class)method.Creates a query that selects scalar values and uses routing based on the provided DataMap name.
- 
scalarQueryCreates query that selects scalar value and uses default routing- Since:
- 4.1
 
- 
scalarQueryCreates query that selects scalar value and uses default routing- Since:
- 4.1
 
- 
scalarQueryDeprecated.since 4.2. UsecolumnQuery(String)Creates query that selects scalar value and uses default routing- Since:
- 4.1
 
- 
columnQueryCreates query that selects scalar values (as Object[]) and uses default routing- Since:
- 4.2
 
- 
scalarQueryDeprecated.since 4.2. UsecolumnQuery(String, String)Creates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.- Since:
- 4.1
 
- 
columnQueryCreates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.- Since:
- 4.2
 
- 
scalarQueryDeprecated.since 4.2. UsecolumnQuery(String, Class...)Creates query that selects scalar values (as Object[]) and uses default routing- Since:
- 4.1
 
- 
columnQueryCreates query that selects scalar values (as Object[]) and uses default routing- Since:
- 4.2
 
- 
scalarQuery@Deprecated public static SQLSelect<Object[]> scalarQuery(String sql, String dataMapName, Class<?>... types) Deprecated.since 4.2. UsecolumnQuery(String, String, Class...)Creates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.- Since:
- 4.1
 
- 
columnQueryCreates query that selects scalar values (as Object[]) and uses routing based on the provided DataMap name.- Since:
- 4.2
 
- 
selectDescription copied from interface:SelectSelects objects using provided context.Essentially the inversion of "ObjectContext.select(Select)". 
- 
selectOneDescription copied from interface:SelectSelects a single object using provided context. The query is expected to match zero or one object. It returns null if no objects were matched. If query matched more than one object,CayenneRuntimeExceptionis thrown.Essentially the inversion of "ObjectContext.selectOne(Select)". 
- 
selectFirstDescription copied from interface:SelectSelects a single object using provided context. The query itself can match any number of objects, but will return only the first one. It returns null if no objects were matched.If it matched more than one object, the first object from the list is returned. This makes 'selectFirst' different from Select.selectOne(ObjectContext), which would throw in this situation. 'selectFirst' is useful e.g. when the query is ordered and we only want to see the first object (e.g. "most recent news article"), etc.Selecting the first object via "Select.selectFirst(ObjectContext)" is more comprehensible than selecting via "ObjectContext.selectFirst(Select)", because implementations of "Select" set fetch size limit to one. - Specified by:
- selectFirstin interface- Select<T>
 
- 
iterateDescription copied from interface:SelectCreates a ResultIterator based on the provided context and passes it to a callback for processing. The caller does not need to worry about closing the iterator. This method takes care of it.Essentially the inversion of "ObjectContext.iterate(Select, ResultIteratorCallback)". 
- 
iteratorDescription copied from interface:SelectCreates a ResultIterator based on the provided context. It is usually backed by an open result set and is useful for processing of large data sets, preserving a constant memory footprint. The caller must wrap iteration in try/finally (or try-with-resources for Java 1.7 and higher) and close the ResultIterator explicitly. Or useSelect.iterate(ObjectContext, ResultIteratorCallback)as an alternative.Essentially the inversion of "ObjectContext.iterator(Select)". 
- 
batchIteratorDescription copied from interface:SelectCreates a ResultBatchIterator based on the provided context and batch size. It is usually backed by an open result set and is useful for processing of large data sets, preserving a constant memory footprint. The caller must wrap iteration in try/finally (or try-with-resources for Java 1.7 and higher) and close the ResultBatchIterator explicitly.- Specified by:
- batchIteratorin interface- Select<T>
 
- 
isFetchingDataRowspublic boolean isFetchingDataRows()
- 
getSql
- 
appendAppends a piece of SQL to the previously stored SQL template.
- 
paramsDeprecated.since 4.2 Useparam(String, Object)
- 
param- Since:
- 4.2
 
- 
params
- 
paramsArrayInitializes positional parameters of the query. Parameters are bound in the order they are found in the SQL template. If a given parameter name is used more than once, only the first occurrence is treated as "position", subsequent occurrences are bound with the same value as the first one. If template parameters count is different from the array parameter count, an exception will be thrown.Note that calling this method will reset any previously set *named* parameters. 
- 
paramsListInitializes positional parameters of the query. Parameters are bound in the order they are found in the SQL template. If a given parameter name is used more than once, only the first occurrence is treated as "position", subsequent occurrences are bound with the same value as the first one. If template parameters count is different from the list parameter count, an exception will be thrown.Note that calling this method will reset any previously set *named* parameters. 
- 
getParamsReturns a potentially immmutable map of named parameters that will be bound to SQL.
- 
getPositionalParamsReturns a potentially immmutable list of positional parameters that will be bound to SQL.
- 
createReplacementQueryDescription copied from class:IndirectQueryCreates a substitute query. An implementor is free to provide an arbitrary replacement query.- Specified by:
- createReplacementQueryin class- IndirectQuery
 
- 
localCacheInstructs Cayenne to look for query results in the "local" cache when running the query. This is a short-hand notation for:query.cacheStrategy(QueryCacheStrategy.LOCAL_CACHE); 
- 
localCacheInstructs Cayenne to look for query results in the "local" cache when running the query. This is a short-hand notation for:query.cacheStrategy(QueryCacheStrategy.LOCAL_CACHE, cacheGroup); 
- 
getCacheStrategy
- 
cacheStrategy
- 
cacheStrategy
- 
getCacheGroup
- 
cacheGroup
- 
getColumnNameCapsReturns a column name capitalization policy applied to selecting queries. This is used to simplify mapping of the queries like "SELECT * FROM ...", ensuring that a chosen Cayenne column mapping strategy (e.g. all column names in uppercase) is portable across database engines that can have varying default capitalization. Default (null) value indicates that column names provided in result set are used unchanged.
- 
columnNameCapsSets a column name capitalization policy applied to selecting queries. This is used to simplify mapping of the queries like "SELECT * FROM ...", ensuring that a chosen Cayenne column mapping strategy (e.g. all column names in uppercase) is portable across database engines that can have varying default capitalization. Default (null) value indicates that column names provided in result set are used unchanged.Note that while a non-default setting is useful for queries that do not rely on a #result directive to describe columns, it works for all SQLTemplates the same way. 
- 
upperColumnNamesEquivalent of settingCapsStrategy.UPPER
- 
lowerColumnNamesEquivalent of settingCapsStrategy.LOWER
- 
getLimitpublic int getLimit()
- 
limit
- 
getOffsetpublic int getOffset()
- 
offset
- 
getPageSizepublic int getPageSize()
- 
pageSize
- 
statementFetchSizeSets JDBC statement's fetch size (0 for no default size)
- 
queryTimeoutSets query timeout- Since:
- 4.2
 
- 
getStatementFetchSizepublic int getStatementFetchSize()- Returns:
- JBDC statement's fetch size
 
- 
getQueryTimeoutpublic int getQueryTimeout()
- 
addPrefetchMerges a prefetch path with specified semantics into the query prefetch tree.- Parameters:
- path- Path expression
- semantics- Defines a strategy to prefetch relationships. See- PrefetchTreeNode
- Returns:
- this object
- Since:
- 4.1
 
- 
addPrefetchMerges a prefetch into the query prefetch tree.- Parameters:
- node- Prefetch which will added to query prefetch tree
- Returns:
- this object
- Since:
- 4.1
 
- 
mapMap result of this query by processing with a given function.
 Could be used to map plain Object[] to some domain-specific object.
 Note: this method could be called multiple time, result will be mapped by all functions in the call order.- Type Parameters:
- E- new result type
- Parameters:
- mapper- function that maps result to the required type.
- Returns:
- this query with changed result type
- Since:
- 4.2
- See Also:
 
 
- 
param(String, Object)