org.eclipse.persistence.jpa.jpql.parser.WhereClause Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of eclipselink Show documentation
Show all versions of eclipselink Show documentation
EclipseLink build based upon Git transaction f2b9fc5
/*
* Copyright (c) 2006, 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 - initial API and implementation
//
package org.eclipse.persistence.jpa.jpql.parser;
import org.eclipse.persistence.jpa.jpql.WordParser;
/**
* The WHERE clause of a query consists of a conditional expression used to select objects or
* values that satisfy the expression. The WHERE clause restricts the result of a select
* statement or the scope of an update or delete operation.
*
* BNF: where_clause ::= WHERE conditional_expression
*
* @version 2.5
* @since 2.3
* @author Pascal Filion
*/
public final class WhereClause extends AbstractConditionalClause {
/**
* Creates a new WhereClause
.
*
* @param parent The parent of this expression
*/
public WhereClause(AbstractExpression parent) {
super(parent, WHERE);
}
@Override
protected boolean isParsingComplete(WordParser wordParser, String word, Expression expression) {
if (word.equalsIgnoreCase(SELECT) ||
word.equalsIgnoreCase(FROM)) {
return false;
}
return super.isParsingComplete(wordParser, word, expression);
}
@Override
public void accept(ExpressionVisitor visitor) {
visitor.visit(this);
}
@Override
public JPQLQueryBNF getQueryBNF() {
return getQueryBNF(WhereClauseBNF.ID);
}
}