Package org.apache.openjpa.kernel
Interface StoreQuery.Executor
- All Known Implementing Classes:
AbstractStoreQuery.AbstractExecutor
,ExpressionStoreQuery.AbstractExpressionExecutor
,ExpressionStoreQuery.DataStoreExecutor
,ExpressionStoreQuery.InMemoryExecutor
,PreparedSQLStoreQuery.PreparedSQLExecutor
,SQLStoreQuery.SQLExecutor
,StoredProcedureQuery.StoredProcedureQueryExecutor
- Enclosing interface:
- StoreQuery
public static interface StoreQuery.Executor
An executor provides a uniform interface to the mechanism for executing
either an in-memory or datastore query. In the common case, the
executeQuery(org.apache.openjpa.kernel.StoreQuery, java.lang.Object[], org.apache.openjpa.kernel.StoreQuery.Range)
method will be called before other methods,
though this is not guaranteed.- Author:
- Marc Prud'hommeaux
-
Method Summary
Modifier and TypeMethodDescriptionexecuteDelete
(StoreQuery q, Object[] params) Deleted the objects that result from the execution of the query, retuning the number of objects that were deleted.executeQuery
(StoreQuery q, Object[] params, StoreQuery.Range range) Return the result of executing this query with the given parameter values.executeUpdate
(StoreQuery q, Object[] params) Updates the objects that result from the execution of the query, retuning the number of objects that were updated.Return an array of all persistent classes used in this query, or empty array if unknown.If this is not a projection but the candidate results are placed into a result class with an alias, return that alias.boolean[]
Return the ordering direction for all ordering clauses, or empty array if none.String[]
getDataStoreActions
(StoreQuery q, Object[] params, StoreQuery.Range range) Return a description of the commands that will be sent to the datastore in order to execute the query.int
Returns the operation this executor is meant to execute.OrderedMap<Object,
Class<?>> Return a map of parameter names to types.getOrderingValue
(StoreQuery q, Object[] params, Object resultObject, int orderIndex) Extract the value of theorderIndex
th ordering expression inQuery#getOrderingClauses
from the given result object.Deprecated.String[]
Return the alias for each projection element, or empty array if not a projection.Class<?>[]
Return the expected types of the projections used by this query, or an empty array if not a projection.Return the parsed query expressions for our candidate types.void
getRange
(StoreQuery q, Object[] params, StoreQuery.Range range) Mutate the given range to set any range information stored in the query string and/or parameters.Class<?>
Returns the result class, if any.ResultShape<?>
Return a map ofFieldMetaData
to updateConstant
s, in cases where this query is for a bulk update.boolean
Whether the compiled query has grouping.boolean
Return true if the compiled query is an aggregate.boolean
boolean
Return true if this executor packs projections into the result class itself.Object[]
toParameterArray
(StoreQuery q, Map<?, ?> userParams) Return an array from the given user parameter values.void
Validate components of query.
-
Method Details
-
executeQuery
Return the result of executing this query with the given parameter values. If this query is a projection and this executor does not pack results itself, each element of the returned result object provider should be an object array containing the projection values.- Parameters:
lrs
- true if the query result should be treated as a large result set, assuming the query is not an aggregate and does not have grouping- See Also:
-
executeDelete
Deleted the objects that result from the execution of the query, retuning the number of objects that were deleted. -
executeUpdate
Updates the objects that result from the execution of the query, retuning the number of objects that were updated. -
getDataStoreActions
Return a description of the commands that will be sent to the datastore in order to execute the query. -
validate
Validate components of query. -
getRange
Mutate the given range to set any range information stored in the query string and/or parameters. -
getOrderingValue
Extract the value of theorderIndex
th ordering expression inQuery#getOrderingClauses
from the given result object. The result object will be an object from the result object provider returned fromexecuteQuery(org.apache.openjpa.kernel.StoreQuery, java.lang.Object[], org.apache.openjpa.kernel.StoreQuery.Range)
. This method is used when several result lists have to be merged in memory. If this exeuctor's parent query supports executors on abstract or interface classes, this method will not be used.- See Also:
-
getAscending
Return the ordering direction for all ordering clauses, or empty array if none. -
isPacking
Return true if this executor packs projections into the result class itself. Executors for query languages that allow projections without result clauses must return true and perform the result packing themselves. -
getAlias
If this is not a projection but the candidate results are placed into a result class with an alias, return that alias. -
getProjectionAliases
Return the alias for each projection element, or empty array if not a projection. -
getProjectionTypes
Return the expected types of the projections used by this query, or an empty array if not a projection. -
getAccessPathMetaDatas
Return an array of all persistent classes used in this query, or empty array if unknown. -
getOperation
Returns the operation this executor is meant to execute.- See Also:
-
isAggregate
Return true if the compiled query is an aggregate. -
isDistinct
-
hasGrouping
Whether the compiled query has grouping. -
getOrderedParameterTypes
Return a map of parameter names to types. The returnedMap.entrySet()
'sIterator
must return values in the order in which they were declared or used. -
getParameterTypes
Deprecated.Return a map of parameter names to types. The returnedMap.entrySet()
'sIterator
must return values in the order in which they were declared or used.
Warning: Deprecated. Use getOrderedParameterTypes(StoreQuery) instead. -
toParameterArray
Return an array from the given user parameter values. The array ordering is same as what this executor expects for its executeXXX() methods as its Object[] parameters. If the given userParams is null or empty return an empty array rather than null.- Returns:
- array with parameter values ordered in the same way as this receiver's executeXXX() method expects.
- Since:
- 2.0.0
-
getResultClass
Returns the result class, if any. -
getResultShape
-
getUpdates
Return a map ofFieldMetaData
to updateConstant
s, in cases where this query is for a bulk update. -
getQueryExpressions
QueryExpressions[] getQueryExpressions()Return the parsed query expressions for our candidate types. The expressions are available only after query has been parsed.- Since:
- 2.0.0
-