All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.openjpa.kernel.exps.ExpressionFactory Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.openjpa.kernel.exps;

import java.util.Date;

import org.apache.openjpa.meta.ClassMetaData;

/**
 * The ExpressionFactory must be implemented by a particular runtime
 * to form {@link Expression}s in its native query language.
 *
 * @author Abe White
 */
public interface ExpressionFactory {

    /**
     * Return a blank expression; this is used when the filter is empty.
     */
    Expression emptyExpression();

    /**
     * Return the given value as an expression.
     */
    Expression asExpression(Value bool);

    /**
     * Return an expression representing the given condition.
     */
    Expression equal(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression notEqual(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression lessThan(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression greaterThan(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression lessThanEqual(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression greaterThanEqual(Value v1, Value v2);

    /**
     * Return an expression representing the given condition.
     */
    Expression isEmpty(Value target);

    /**
     * Return an expression representing the given condition.
     */
    Expression isNotEmpty(Value target);

    /**
     * Return an expression representing the given condition.
     */
    Expression contains(Value coll, Value arg);

    /**
     * Return an expression representing the given condition.
     */
    Expression containsKey(Value map, Value arg);

    /**
     * Return an expression representing the given condition.
     */
    Expression containsValue(Value map, Value arg);

    /**
     * Return an expression representing the given condition.
     */
    Value getMapValue(Value map, Value arg);

    /**
     * Return whether the first value is an instance of the given class.
     */
    Expression isInstance(Value obj, Class c);

    /**
     * Return the two expressions AND'd together.
     */
    Expression and(Expression exp1, Expression exp2);

    /**
     * Return the two expressions OR'd together.
     */
    Expression or(Expression exp1, Expression exp2);

    /**
     * Return the inverse of this expression.
     */
    Expression not(Expression exp);

    /**
     * Bind the given variable to the given collection value.
     */
    Expression bindVariable(Value var, Value coll);

    /**
     * Bind the given variable to the key set of the given map value.
     */
    Expression bindKeyVariable(Value var, Value map);

    /**
     * Bind the given variable to the value set of the given map value.
     */
    Expression bindValueVariable(Value var, Value map);

    /**
     * Return whether the first string ends with the second.
     */
    Expression endsWith(Value str1, Value str2);

    /**
     * Return whether the string matches the matching pattern.
     *
     * @param str the value to compare
     * @param regexp the pattern against which to compare
     * @param single the token that signifies a single-character match
     * @param multi the token that signifies a multi-character match
     * @param escape the escape token that escapes the matching tokens
     */
    Expression matches(Value str, Value regexp,
        String single, String multi, String escape);

    /**
     * Return whether the string does not match the given pattern.
     *
     * @param str the value to compare
     * @param regexp the pattern against which to compare
     * @param single the token that signifies a single-character match
     * @param multi the token that signifies a multi-character match
     * @param escape the escape token that escapes the matching tokens
     */
    Expression notMatches(Value str, Value regexp, String single,
        String multi, String escape);

    /**
     * Return whether the first string starts with the second.
     */
    Expression startsWith(Value str1, Value str2);

    /**
     * Returns the number of characters in the String value.
     */
    Value stringLength(Value str);

    /**
     * Trims the specified specified trimChar from the specified value.
     *
     * @param str the value from which to trim
     * @param trimChar the characters to trim off
     * @param where which side of the String to trim: null
     * indicates both sides, true indicates
     * leading, and false indicates trailing
     */
    Value trim(Value str, Value trimChar, Boolean where);

    /**
     * Return a subquery. Paths for the candidates of the subquery are
     * created with {@link #newPath(Value)}, passing in the subquery as the
     * value.
     *
     * @param candidate the candidate class of the subquery
     * @param subs whether the query includes subclasses
     * @param alias the alias given to the query candidate class
     */
    Subquery newSubquery(ClassMetaData candidate, boolean subs,
        String alias);

    /**
     * Return a value representing a path which will consist
     * of a chain of 1 or more field names starting in the namespace of the
     * candidate class.
Example: parent.address.city */ Path newPath(); /** * Return a value representing a path which will consist * of a chain of 1 or more field names starting in the namespace of the * given value.
Example: var.address.city */ Path newPath(Value val); /** * Return a value representing the given constant, which will be * a {@link Number}, {@link String}, or {@link Boolean} instance. */ Literal newLiteral(Object val, int parseType); /** * Return a value representing this. */ Value getThis(); /** * Return a value representing null. */ Value getNull(); /** * Return a value representing the current date. */ Value getCurrentDate(Class dateType); /** * Return a value representing the current time. */ Value getCurrentTime(Class timeType); /** * Return a value representing the current timestamp. */ Value getCurrentTimestamp(Class timestampType); /** * Return a value representing a parameter for the given value. The * type may be Object if the parameter is not declared. */ Parameter newParameter(Object name, Class type); /** * Return a value representing a collection-valued parameter. The * type may be Object if the parameter is not declared. */ Parameter newCollectionValuedParameter(Object name, Class type); /** * Return the value of the given extension. */ Value newExtension(FilterListener listener, Value target, Value args); /** * Return the value of the given function. */ Value newAggregate(AggregateListener listener, Value args); /** * Return a function argument list consisting of the given values, either * of which may itself be an argument list. */ Arguments newArgumentList(Value arg1, Value arg2); /** * Return a function argument list consisting of the given values, any * of which may itself be an argument list. */ Arguments newArgumentList(Value... values); /** * Return an unbound variable. This method will only be called once for * a given named unbound variable. The type may be Object * if the variable is not declared. */ Value newUnboundVariable(String name, Class type); /** * This method will be called only once per variable bound in a * contains clause, and the returned value will be reused * for any further instances of the variable in subexpression of the * filter string. The type may be Object if the variable is * not declared. */ Value newBoundVariable(String name, Class type); /** * Cast the value to the given class. */ Value cast(Value obj, Class cls); /** * Return a value representing the two values added together. */ Value add(Value num1, Value num2); /** * Return a value representing the second value subtracted from the first. */ Value subtract(Value num1, Value num2); /** * Return a value representing the two values multiplied together. */ Value multiply(Value num1, Value num2); /** * Return a value representing the first value divided by the first one. */ Value divide(Value num1, Value num2); /** * Return a value representing the first value mod'd by the second one. */ Value mod(Value num1, Value num2); /** * Return a value representing the absolute value of the given one. */ Value abs(Value num); /** * Return a value representing the indexOf (LOCATE in JPQL) function on * the given target with the given args. * The optional second argument is one-based. */ Value indexOf(Value str, Value args); /** * Return a value representing the concatenation of * the given target with the given args. */ Value concat(Value str, Value args); /** * Return the square root of the given value. */ Value sqrt(Value num); /** * Return a value representing the substring function on * the given target with the given args. Unlike as with {@link String#substring}, * the start index is one-based, and the second argument is the length. */ Value substring(Value str, Value args); /** * Return the upper case of the given value. */ Value toUpperCase(Value str); /** * Return the upper case of the given value. */ Value toLowerCase(Value str); /** * Return the average of the given value for all matches. */ Value avg(Value num); /** * Return the count of the given value for all matches. */ Value count(Value obj); /** * Return the max of the given value for all matches. */ Value max(Value num); /** * Return the max of the given value for all matches. */ Value min(Value num); /** * Return the max of the given value for all matches. */ Value sum(Value num); /** * Return an expression representing the given condition. * * @since 0.4.0.0 */ Value any(Value target); /** * Return an expression representing the given condition. * * @since 0.4.0.0 */ Value all(Value target); /** * Return an expression representing the given condition. * * @since 0.4.0.0 */ Value size(Value target); /** * Return an index/position of the given value within a collection/map. * * @since 2.0.0 */ Value index(Value target); /** * Return the type/class of the given value. * * @since 2.0.0 */ Value type(Value target); /** * Return the map entry of the given value. * * @since 2.0.0 */ Value mapEntry(Value key, Value val); /** * Return the map key of the given value */ Value mapKey(Value key, Value val); /** * Path navigation thru map key */ Value getKey(Value val); /** * Return distinct values of the given value. This is typically used * within aggregates, for example: max(distinct(path)) * * @since 0.4.0.0 */ Value distinct (Value obj); /** * Return the object id of the given value. */ Value getObjectId (Value val); /** * Return a simple case expression */ Value simpleCaseExpression(Value caseOperand, Expression[] exp, Value val); /** * Return a general case expression */ Value generalCaseExpression(Expression[] exp, Value val); /** * Return a when condidional clause */ Expression whenCondition(Expression exp, Value val); /** * Return a when scalar_expression clause */ Expression whenScalar(Value val1, Value val2); /** * Return a coalesce expression */ Value coalesceExpression(Value[] val); /** * Return a nullif expression */ Value nullIfExpression(Value val1, Value val2); /** * Return a value representing the given constant, which will be * a {@link Number}, {@link String}, or {@link Boolean} instance. */ Literal newTypeLiteral(Object val, int parseType); /** * Return a value representing the given datastore function with the given arguments. */ Value newFunction(String functionName, Class resultType, Value... args); /** * Return true if the Value is a Type expression and the Type uses joined table strategy. */ boolean isVerticalType(Value val); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy