Class EclipseLinkJPQLGrammar2_1
java.lang.Object
org.eclipse.persistence.jpa.jpql.parser.AbstractJPQLGrammar
org.eclipse.persistence.jpa.jpql.parser.EclipseLinkJPQLGrammar2_1
- All Implemented Interfaces:
JPQLGrammar
This JPQLGrammar
provides support for parsing JPQL queries defined in JSR-337 - Java Persistence 2.0 and the additional
support provided by EclipseLink 2.1.
join ::= join_spec { join_association_path_expression | join_treat_association_path_expression } [AS] identification_variable
join_treat_association_path_expression ::= TREAT(join_association_path_expression AS entity_type_literal)
func_expression ::= FUNC(string_literal {, func_item}*)
func_item ::= new_value
between_expression ::= scalar_expression [NOT] BETWEEN scalar_expression AND scalar_expression
in_expression ::= in_expression_expression [NOT] IN { ( in_item {, in_item}* ) | (subquery) | collection_valued_input_parameter }
in_expression_expression ::= { state_field_path_expression | type_discriminator |
single_valued_input_parameter | identification_variable |
scalar_expression }
in_item ::= literal | single_valued_input_parameter | scalar_expression
scalar_expression ::= arithmetic_expression |
...
pattern_value ::= scalar_expression | arithmetic_expression
escape_character ::= scalar_expression
functions_returning_numerics ::= LENGTH(scalarExpression) |
LOCATE(scalarExpression, scalarExpression[, scalarExpression]) |
MOD(scalarExpression, scalarExpression) |
SQRT(scalarExpression)
func_expression |
...
functions_returning_strings ::= CONCAT(scalar_expression {, scalar_expression }+) |
SUBSTRING(scalar_expression, scalar_expression [, scalar_expression]) |
LOWER(scalar_expression) |
UPPER(scalar_expression) |
func_expression |
...
orderby_item ::= state_field_path_expression | result_variable | scalar_expression [ ASC | DESC ]
groupby_item ::= single_valued_path_expression | identification_variable | scalar_expression
aggregate_expression ::= { AVG | MAX | MIN | SUM | COUNT } ([DISTINCT] scalar_expression)
Provisional API: This interface is part of an interim API that is still under development and expected to change significantly before reaching stability. It is available at this early stage to solicit feedback from pioneering adopters on the understanding that any code that uses this API will almost certainly be broken (repeatedly) as the API evolves.
- Version:
- 2.5
- Author:
- Pascal Filion
-
Field Summary
Modifier and TypeFieldDescriptionstatic final EclipseLinkVersion
The EclipseLink version, which is 2.1. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected JPQLGrammar
Creates the baseJPQLGrammar
this one extends, if one exists.static void
extend
(AbstractJPQLGrammar jpqlGrammar) Extends the givenJPQLGrammar
with the information of this one without instantiating the baseJPQLGrammar
.Returns theJPAVersion
of the Java Persistence supported by this grammar.Returns the persistence provider name.Returns the version of the persistence provider.protected void
Registers the JPQL query BNFs defining the JPQL grammar.protected void
Registers theExpressionFactories
required to properly parse JPQL queries.protected void
Registers the JPQL identifiers support by thisJPQLGrammar
.static JPQLGrammar
instance()
Returns the singleton instance of this class.toString()
Methods inherited from class org.eclipse.persistence.jpa.jpql.parser.AbstractJPQLGrammar
addChildBNF, addChildFactory, addIdentifier, addIdentifiers, buildExpressionRegistry, getBaseGrammar, getExpressionRegistry, initialize, registerBNF, registerFactory, registerIdentifierRole, registerIdentifierVersion, setFallbackBNFId, setFallbackExpressionFactoryId, setHandleCollection, setHandleNestedArray, setHandleSubExpression
-
Field Details
-
VERSION
The EclipseLink version, which is 2.1.
-
-
Constructor Details
-
EclipseLinkJPQLGrammar2_1
public EclipseLinkJPQLGrammar2_1()Creates a newEclipseLinkJPQLGrammar2_1
.
-
-
Method Details
-
extend
Extends the givenJPQLGrammar
with the information of this one without instantiating the baseJPQLGrammar
.- Parameters:
jpqlGrammar
- TheJPQLGrammar
to extend with the content of this one without instantiating the baseJPQLGrammar
-
instance
Returns the singleton instance of this class.- Returns:
- The
EclipseLinkJPQLGrammar2_1
-
buildBaseGrammar
Description copied from class:AbstractJPQLGrammar
Creates the baseJPQLGrammar
this one extends, if one exists.IMPORTANT: The singleton instance of any
JPQLGrammar
(for exampleJPQLGrammar1_0.instance()
cannot be used, the API does not support extending it, a new instance has to be created.- Specified by:
buildBaseGrammar
in classAbstractJPQLGrammar
- Returns:
- The base
JPQLGrammar
ornull
if there is no base grammar
-
getJPAVersion
Description copied from interface:JPQLGrammar
Returns theJPAVersion
of the Java Persistence supported by this grammar.- Returns:
- The
JPA version
supported by this grammar
-
getProvider
Description copied from interface:JPQLGrammar
Returns the persistence provider name.- Returns:
- The name of the persistence provider,
null
should never be returned
-
getProviderVersion
Description copied from interface:JPQLGrammar
Returns the version of the persistence provider.- Returns:
- The version of the persistence provider, if one is extending the default JPQL grammar defined in the Java Persistence specification, otherwise returns an empty string
-
initializeBNFs
protected void initializeBNFs()Description copied from class:AbstractJPQLGrammar
Registers the JPQL query BNFs defining the JPQL grammar.- Specified by:
initializeBNFs
in classAbstractJPQLGrammar
-
initializeExpressionFactories
protected void initializeExpressionFactories()Description copied from class:AbstractJPQLGrammar
Registers theExpressionFactories
required to properly parse JPQL queries. AnExpressionFactory
is responsible to create anExpression
object that represents a portion of the JPQL query.- Specified by:
initializeExpressionFactories
in classAbstractJPQLGrammar
-
initializeIdentifiers
protected void initializeIdentifiers()Description copied from class:AbstractJPQLGrammar
Registers the JPQL identifiers support by thisJPQLGrammar
. The registration involves registering theJPAVersion
and theIdentifierRole
.- Specified by:
initializeIdentifiers
in classAbstractJPQLGrammar
-
toString
-