org.eclipse.persistence.queries.JPAQueryBuilder Maven / Gradle / Ivy
/*
* Copyright (c) 1998, 2020 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/
// Contributors:
// Oracle
//
package org.eclipse.persistence.queries;
import org.eclipse.persistence.expressions.Expression;
import org.eclipse.persistence.internal.jpa.jpql.HermesParser;
import org.eclipse.persistence.internal.sessions.AbstractSession;
/**
* This interface defines the entry point for implementing a JPQL query parsing
* system in EclipseLink.
*
* By default, EclipseLink uses {@link HermesParser} for parsing a query
* and converting it into a {@link DatabaseQuery}.
*
* Third-parties can implement this interface and provide a different JPQL
* parsing system if required. The {@link JPAQueryBuilder} implementing class
* can be registered via a persistence unit property and the implementation
* class must have a public, zero-arg constructor.
*
* @version 2.4
* @since 2.2
* @author John Bracken
* @author Pascal Filion
*/
public interface JPAQueryBuilder {
/**
* Allow the parser validation level to be set.
*
* @param level
* The validation levels are defined in ParserValidationType
*/
void setValidationLevel(String level);
/**
* Creates a fully initialized {@link DatabaseQuery} by parsing the given
* JPQL query.
*
* @param jpqlQuery
* A non-null
string representation of the query to
* parse and to convert into a {@link DatabaseQuery}
* @param session
* The EclipseLink {@link AbstractSession} that this query will
* execute against
* @return The fully initialized {@link DatabaseQuery}
*/
DatabaseQuery buildQuery(CharSequence jpqlQuery, AbstractSession session);
/**
* Creates a new {@link Expression} that represents the given selection
* criteria.
*
* @param entityName
* The name of the entity for which a criteria is created
* @param selectionCriteria
* The string representation of a conditional expression to parse
* @param session
* The EclipseLink {@link AbstractSession} that this query will
* execute against
* @return The fully initialized {@link Expression}
*/
Expression buildSelectionCriteria(String entityName,
String selectionCriteria,
AbstractSession session);
/**
* Populates the given {@link DatabaseQuery} by parsing the given JPQL
* query.
*
* @param jpqlQuery
* A non-null
string representation of the query to
* parse and to convert into a {@link DatabaseQuery}
* @param query
* The query to populate with the derived JPQL query
* @param session
* The EclipseLink {@link AbstractSession} that this query will
* execute against
*/
void populateQuery(CharSequence jpqlQuery, DatabaseQuery query, AbstractSession session);
}