public abstract class AggregateFunction extends AbstractSingleEncapsulatedExpression
 A single_valued_association_field is designated by the name of an association-field
 in a one-to-one or many-to-one relationship. The type of a single_valued_association_field
 and thus a single_valued_association_path_expression is the abstract schema type of
 the related entity.
 
The argument to an aggregate function may be preceded by the keyword DISTINCT to specify that duplicate values are to be eliminated before the aggregate function is applied. Null values are eliminated before the aggregate function is applied, regardless of whether the keyword DISTINCT is specified.
aggregate_expression ::= { AVG | MAX | MIN | SUM } ([DISTINCT] state_field_path_expression) |
                          COUNT ([DISTINCT] identification_variable |
                                            state_field_path_expression |
                                            single_valued_object_path_expression)AvgFunction, 
CountFunction, 
MaxFunction, 
MinFunction, 
SumFunctionCOMMA, DOT, DOUBLE_QUOTE, LEFT_CURLY_BRACKET, LEFT_PARENTHESIS, NOT_DEFINED, RIGHT_CURLY_BRACKET, RIGHT_PARENTHESIS, SINGLE_QUOTE, SPACE, UNDERSCOREABS, ALL, AND, ANY, AS, AS_OF, ASC, AVG, BETWEEN, BIT_LENGTH, BOTH, CASE, CAST, CHAR_LENGTH, CHARACTER_LENGTH, CLASS, COALESCE, COLUMN, CONCAT, CONNECT_BY, COUNT, CURRENT_DATE, CURRENT_TIME, CURRENT_TIMESTAMP, DELETE, DELETE_FROM, DESC, DIFFERENT, DISTINCT, DIVISION, ELSE, EMPTY, END, ENTRY, EQUAL, ESCAPE, EXCEPT, EXISTS, EXTRACT, FALSE, FETCH, FIRST, FROM, FUNC, FUNCTION, GREATER_THAN, GREATER_THAN_OR_EQUAL, GROUP_BY, HAVING, IN, INDEX, INNER, INNER_JOIN, INNER_JOIN_FETCH, INTERSECT, IS, IS_EMPTY, IS_NOT_EMPTY, IS_NOT_NULL, IS_NULL, JOIN, JOIN_FETCH, KEY, LAST, LEADING, LEFT, LEFT_JOIN, LEFT_JOIN_FETCH, LEFT_OUTER_JOIN, LEFT_OUTER_JOIN_FETCH, LENGTH, LIKE, LOCATE, LOWER, LOWER_THAN, LOWER_THAN_OR_EQUAL, MAX, MEMBER, MEMBER_OF, MIN, MINUS, MOD, MULTIPLICATION, NAMED_PARAMETER, NEW, NOT, NOT_BETWEEN, NOT_EQUAL, NOT_EXISTS, NOT_IN, NOT_LIKE, NOT_MEMBER, NOT_MEMBER_OF, NULL, NULLIF, NULLS, NULLS_FIRST, NULLS_LAST, OBJECT, OF, ON, OPERATOR, OR, ORDER_BY, ORDER_SIBLINGS_BY, OUTER, PLUS, POSITION, POSITIONAL_PARAMETER, QUOTE, REGEXP, SCN, SELECT, SET, SIZE, SOME, SQL, SQRT, START_WITH, SUBSTRING, SUM, TABLE, THEN, TIMESTAMP, TRAILING, TREAT, TRIM, TRUE, TYPE, UNION, UNKNOWN, UPDATE, UPPER, VALUE, WHEN, WHERE| Modifier | Constructor and Description | 
|---|---|
| protected  | AggregateFunction(AbstractExpression parent,
                 java.lang.String identifier)Creates a new  AggregateFunction. | 
| Modifier and Type | Method and Description | 
|---|---|
| protected void | addOrderedEncapsulatedExpressionTo(java.util.List<Expression> children)Adds the  Expressionsrepresenting the encapsulatedExpression. | 
| protected AbstractExpression | buildEncapsulatedExpression(WordParser wordParser,
                           java.lang.String word)Creates the  AbstractExpressionto represent the given word. | 
| java.lang.String | getActualDistinctIdentifier()Returns the actual DISTINCT identifier found in the string representation of the JPQL
 query, which has the actual case that was used. | 
| java.lang.String | getEncapsulatedExpressionQueryBNFId()Returns the BNF used to parse the encapsulated expression. | 
| JPQLQueryBNF | getQueryBNF()Returns the BNF of this  Expression. | 
| boolean | hasDistinct()Determines whether the DISTINCT identifier was specified in the query. | 
| boolean | hasSpaceAfterDistinct()Determines whether a whitespace was parsed after DISTINCT. | 
| protected void | parseEncapsulatedExpression(WordParser wordParser,
                           int whitespaceCount,
                           boolean tolerant)Parses the encapsulated expression by starting at the current position, which is part of the
 given  WordParser. | 
| protected void | toParsedTextEncapsulatedExpression(java.lang.StringBuilder writer,
                                  boolean actual)Generates a string representation of the encapsulated  Expression. | 
acceptChildren, addChildrenTo, findQueryBNF, getExpression, hasEncapsulatedExpression, hasExpression, removeEncapsulatedExpression, setExpressionaddOrderedChildrenTo, areLogicalIdentifiersSupported, getActualIdentifier, getIdentifier, hasLeftParenthesis, hasRightParenthesis, hasSpaceAfterIdentifier, isParsingComplete, parse, shouldParseRightParenthesis, toParsedTextacceptUnknownVisitor, acceptUnknownVisitor, buildExpressionFromFallingBack, buildNullExpression, buildStringExpression, buildStringExpression, buildUnknownExpression, calculatePosition, children, findFallBackExpressionFactory, getExpressionFactory, getExpressionRegistry, getGrammar, getIdentifierVersion, getJPAVersion, getLength, getOffset, getParent, getQueryBNF, getRoot, getText, handleAggregate, handleCollection, isAncestor, isIdentifier, isNull, isTolerant, isUnknown, isVirtual, orderedChildren, parse, parseUsingExpressionFactory, populatePosition, rebuildActualText, rebuildParsedText, setParent, setText, shouldParseWithFactoryFirst, shouldSkipLiteral, toActualText, toParsedText, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitacceptprotected AggregateFunction(AbstractExpression parent, java.lang.String identifier)
AggregateFunction.parent - The parent of this expressionidentifier - The JPQL identifier that starts this expressionprotected void addOrderedEncapsulatedExpressionTo(java.util.List<Expression> children)
Expressions representing the encapsulated Expression.addOrderedEncapsulatedExpressionTo in class AbstractSingleEncapsulatedExpressionchildren - The list used to store the string representation of the encapsulated Expressionprotected AbstractExpression buildEncapsulatedExpression(WordParser wordParser, java.lang.String word)
AbstractExpression to represent the given word.word - The word that was parsedAbstractExpressionpublic java.lang.String getEncapsulatedExpressionQueryBNFId()
getEncapsulatedExpressionQueryBNFId in class AbstractSingleEncapsulatedExpressionpublic java.lang.String getActualDistinctIdentifier()
public JPQLQueryBNF getQueryBNF()
Expression.JPQLQueryBNF, which represents the grammar of this Expressionpublic final boolean hasDistinct()
true if the query has DISTINCT; false otherwisepublic final boolean hasSpaceAfterDistinct()
true if there was a whitespace after DISTINCT; false
 otherwiseprotected final void parseEncapsulatedExpression(WordParser wordParser, int whitespaceCount, boolean tolerant)
WordParser.parseEncapsulatedExpression in class AbstractSingleEncapsulatedExpressionwordParser - The text to parse based on the current position of the cursorwhitespaceCount - The number of whitespace characters that were parsed after '('tolerant - Determines whether the parsing system should be tolerant, meaning if it should
 try to parse invalid or incomplete queriesprotected void toParsedTextEncapsulatedExpression(java.lang.StringBuilder writer,
                                      boolean actual)
Expression.toParsedTextEncapsulatedExpression in class AbstractSingleEncapsulatedExpressionwriter - The buffer used to append the encapsulated Expression's string
 representationactual - Determines whether to include any characters that are considered
 virtual, i.e. that was parsed when the query is incomplete and is needed for functionality
 like content assist