|
EclipseLink 2.4.2, build 'v20130514-5956486' API Reference | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.eclipse.persistence.jpa.jpql.model.query.AbstractStateObject org.eclipse.persistence.jpa.jpql.model.query.OrderByItemStateObject
public class OrderByItemStateObject
An ORDER BY
item must be one of the following:
state_field_path_expression
that evaluates to
an orderable state field of an entity or embeddable class abstract schema type designated in the
SELECT
clause by one of the following:
state_field_path_expression
that evaluates to
the same state field of the same entity or embeddable abstract schema type as a state_field_path_expression
in the SELECT clause
result_variable
that refers to an orderable item in the
SELECT
clause for which the same result_variable
has been specified. This may be the result of an aggregate_expression, a scalar_expression
,
or a state_field_path_expression
in the
SELECT
clause.
The keyword ASC
specifies that ascending ordering be used for the associated
ORDER BY
item; the keyword DESC
specifies that descending
ordering be used. Ascending ordering is the default.
JPA 1.0:
orderby_item ::= state_field_path_expression [ ASC | DESC ]
JPA 2.0
orderby_item ::= state_field_path_expression | result_variable [ ASC | DESC ]
OrderByItem
Field Summary | |
---|---|
static java.lang.String |
ORDERING_PROPERTY
Notifies the ordering property has changed. |
static java.lang.String |
STATE_OBJECT_PROPERTY
Notifies the ordering property has changed. |
Constructor Summary | |
---|---|
OrderByItemStateObject(OrderByClauseStateObject parent)
Creates a new OrderByItemStateObject . |
|
OrderByItemStateObject(OrderByClauseStateObject parent,
OrderByItem.Ordering ordering)
Creates a new OrderByItemStateObject . |
|
OrderByItemStateObject(OrderByClauseStateObject parent,
StateObject stateObject,
OrderByItem.Ordering ordering)
Creates a new OrderByItemStateObject . |
|
OrderByItemStateObject(OrderByClauseStateObject parent,
java.lang.String jpqlFragment,
OrderByItem.Ordering ordering)
Creates a new OrderByItemStateObject . |
Method Summary | |
---|---|
void |
accept(StateObjectVisitor visitor)
Visits this StateObject by the given visitor . |
protected void |
addChildren(java.util.List<StateObject> children)
Adds the children of this StateObject to the given list. |
OrderByItem |
getExpression()
Returns the actual parsed object if this StateObject representation of the JPQL query
was created by parsing an existing JPQL query. |
OrderByItem.Ordering |
getOrdering()
Returns the enum constant representing the ordering type. |
OrderByClauseStateObject |
getParent()
Returns the parent of this StateObject . |
StateObject |
getStateObject()
Returns the StateObject representing the value used for ordering. |
boolean |
hasStateObject()
Determines whether the StateObject representing the value used for ordering has been
defined. |
boolean |
isAscending()
Determines whether the ordering was specified as being ascendant. |
boolean |
isDefault()
Determines whether the ordering was not specified. |
boolean |
isDescending()
Determines whether the ordering was specified as being descendant. |
boolean |
isEquivalent(StateObject stateObject)
Determines whether the given StateObject is equivalent to this one, i.e. the
information of both StateObject is the same. |
void |
parse(java.lang.String jpqlFragment)
Parses the given JPQL fragment, which represents either a state-field pathe expression or a result variable, and creates the StateObject . |
void |
removeOrdering()
Removes the ordering if it's specified, otherwise do nothing. |
void |
setExpression(OrderByItem expression)
Keeps a reference of the parsed object object, which should only be
done when this object is instantiated during the conversion of a parsed JPQL query into
StateObjects . |
void |
setOrdering(OrderByItem.Ordering ordering)
Sets the enum constant representing the ordering type. |
void |
setStateObject(StateObject stateObject)
Sets the StateObject representing the value used for ordering. |
protected void |
toTextInternal(java.lang.Appendable writer)
Prints out a string representation of this StateObject , which should not be used to
define a true string representation of a JPQL query but should be used for
debugging purposes. |
Methods inherited from class org.eclipse.persistence.jpa.jpql.model.query.AbstractStateObject |
---|
acceptUnknownVisitor, acceptUnknownVisitor, addProblems, addPropertyChangeListener, areEquivalent, buildProblem, buildProblem, buildStateObject, buildStateObjects, checkParent, children, decorate, equals, findIdentificationVariable, firePropertyChanged, getChangeSupport, getDeclaration, getDecorator, getGrammar, getManagedTypeProvider, getQueryBuilder, getRoot, getType, getType, getTypeHelper, getTypeRepository, hashCode, initialize, isDecorated, parent, parent, parent, removePropertyChangeListener, setExpression, setParent, toString, toString, toStringInternal, toStringItems, toText |
Methods inherited from class java.lang.Object |
---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
public static final java.lang.String ORDERING_PROPERTY
public static final java.lang.String STATE_OBJECT_PROPERTY
Constructor Detail |
---|
public OrderByItemStateObject(OrderByClauseStateObject parent)
OrderByItemStateObject
.
parent
- The parent of this state object, which cannot be null
java.lang.NullPointerException
- The given parent cannot be null
public OrderByItemStateObject(OrderByClauseStateObject parent, OrderByItem.Ordering ordering)
OrderByItemStateObject
.
parent
- The parent of this state object, which cannot be null
java.lang.NullPointerException
- The given parent cannot be null
public OrderByItemStateObject(OrderByClauseStateObject parent, StateObject stateObject, OrderByItem.Ordering ordering)
OrderByItemStateObject
.
parent
- The parent of this state object, which cannot be null
stateObject
- The StateObject
of the itemordering
- One of the possible OrderByItem.Ordering
choice
java.lang.NullPointerException
- The given parent cannot be null
public OrderByItemStateObject(OrderByClauseStateObject parent, java.lang.String jpqlFragment, OrderByItem.Ordering ordering)
OrderByItemStateObject
.
parent
- The parent of this state object, which cannot be null
jpqlFragment
- The JPQL fragment representing the ordering itemordering
- One of the possible OrderByItem.Ordering
choice
java.lang.NullPointerException
- The given parent cannot be null
Method Detail |
---|
public void accept(StateObjectVisitor visitor)
StateObject
by the given visitor
.
visitor
- The visitor
to visit this objectprotected void addChildren(java.util.List<StateObject> children)
StateObject
to the given list.
addChildren
in class AbstractStateObject
children
- The list used to store the childrenpublic OrderByItem getExpression()
StateObject
representation of the JPQL query
was created by parsing an existing JPQL query.
getExpression
in interface StateObject
getExpression
in class AbstractStateObject
StateObject
or null
when the JPQL query is manually created (i.e. not from a string)public OrderByItem.Ordering getOrdering()
OrderByItem.Ordering.DEFAULT
is returnedpublic OrderByClauseStateObject getParent()
StateObject
.
getParent
in interface StateObject
getParent
in class AbstractStateObject
StateObject
, which is null
only when
this is the root of the hierarchypublic StateObject getStateObject()
StateObject
representing the value used for ordering.
StateObject
representing the value used for orderingpublic boolean hasStateObject()
StateObject
representing the value used for ordering has been
defined.
true
if the ordering value is defined; false
otherwisepublic boolean isAscending()
true
if ASC was parsed; false
otherwisepublic boolean isDefault()
true
if no ordering was parsed; false
otherwisepublic boolean isDescending()
true
if DESC was parsed; false
otherwisepublic boolean isEquivalent(StateObject stateObject)
StateObject
is equivalent to this one, i.e. the
information of both StateObject
is the same.
isEquivalent
in interface StateObject
isEquivalent
in class AbstractStateObject
stateObject
- The StateObject
to compare its content to this one
true
if both object are equivalent; false
otherwisepublic void parse(java.lang.String jpqlFragment)
StateObject
.
jpqlFragment
- The portion of the query representing a state-field path expression or
result variablepublic void removeOrdering()
public void setExpression(OrderByItem expression)
parsed object
object, which should only be
done when this object is instantiated during the conversion of a parsed JPQL query into
StateObjects
.
expression
- The parsed object
representing an order by itempublic void setOrdering(OrderByItem.Ordering ordering)
ordering
- The constant representing the ordering, in the case the ordering was not
parsed, then OrderByItem.Ordering.DEFAULT
should be usedpublic void setStateObject(StateObject stateObject)
StateObject
representing the value used for ordering.
stateObject
- The StateObject
representing the value used for orderingprotected void toTextInternal(java.lang.Appendable writer) throws java.io.IOException
StateObject
, which should not be used to
define a true
string representation of a JPQL query but should be used for
debugging purposes.
toTextInternal
in class AbstractStateObject
writer
- The writer used to print out the string representation
java.io.IOException
- This should never happens, it is only required because Appendable
is used instead of any concrete class
|
EclipseLink 2.4.2, build 'v20130514-5956486' API Reference | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |