Interface JPQLGrammar

All Known Implementing Classes:
AbstractJPQLGrammar, DefaultEclipseLinkJPQLGrammar, DefaultJPQLGrammar, EclipseLinkJPQLGrammar1, EclipseLinkJPQLGrammar2_0, EclipseLinkJPQLGrammar2_1, EclipseLinkJPQLGrammar2_2, EclipseLinkJPQLGrammar2_3, EclipseLinkJPQLGrammar2_4, EclipseLinkJPQLGrammar2_5, EclipseLinkJPQLGrammar2_6, JPQLGrammar1_0, JPQLGrammar2_0, JPQLGrammar2_1

public interface JPQLGrammar

A JPQL grammar defines how a JPQL query can be parsed. The ExpressionRegistry contains the BNFs and the expression factories used to create the tree representation of the JPQL query.

The supported JPQL grammars are:

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
  • Method Details

    • getExpressionRegistry

      ExpressionRegistry getExpressionRegistry()
      Returns the registry containing the JPQLQueryBNFs and the ExpressionFactories that are used to properly parse a JPQL query.
      Returns:
      The registry containing the information related to the JPQL grammar
    • getJPAVersion

      JPAVersion getJPAVersion()
      Returns the JPAVersion of the Java Persistence supported by this grammar.
      Returns:
      The JPA version supported by this grammar
    • getProvider

      String getProvider()
      Returns the persistence provider name.
      Returns:
      The name of the persistence provider, null should never be returned
    • getProviderVersion

      String getProviderVersion()
      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