Package org.h2.expression
Class ValueExpression
java.lang.Object
org.h2.expression.Expression
org.h2.expression.Operation0
org.h2.expression.ValueExpression
- Direct Known Subclasses:
TypedValueExpression
An expression representing a constant value.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final ValueExpressionThis special expression represents the default value.static final ValueExpressionThe expression represents ValueBoolean.FALSE.static final ValueExpressionThe expression represents ValueNull.INSTANCE.static final ValueExpressionThe expression represents ValueBoolean.TRUE.Fields inherited from class org.h2.expression.Expression
AUTO_PARENTHESES, MAP_IN_AGGREGATE, MAP_IN_WINDOW, MAP_INITIAL, WITH_PARENTHESES, WITHOUT_PARENTHESESFields inherited from interface org.h2.util.HasSQL
ADD_PLAN_INFORMATION, DEFAULT_SQL_FLAGS, NO_CASTS, QUOTE_ONLY_WHEN_REQUIRED, REPLACE_LOBS_FOR_TRACE, TRACE_SQL_FLAGS -
Method Summary
Modifier and TypeMethodDescriptionvoidcreateIndexConditions(SessionLocal session, TableFilter filter) Create index conditions if possible and attach them to the table filter.static ValueExpressionCreate a new expression with the given value.static ValueExpressiongetBoolean(boolean value) Create a new expression with the given boolean value.static ValueExpressiongetBoolean(Value value) Create a new expression with the given boolean value.intgetCost()Estimate the cost to process the expression.getNotIfPossible(SessionLocal session) If it is possible, return the negated expression.getType()Returns the data type.getTypeIfStaticallyKnown(SessionLocal session) Returns data type of this expression if it is statically known.getUnenclosedSQL(StringBuilder builder, int sqlFlags) Get the SQL statement of this expression.getValue(SessionLocal session) Return the resulting value for the current row.booleanCheck if this expression will always return the same value.booleanisEverything(ExpressionVisitor visitor) Check if this expression and all sub-expressions can fulfill a criteria.booleanCheck if this expression will always return the NULL value.booleanIs the value of a parameter set.Methods inherited from class org.h2.expression.Operation0
mapColumns, optimize, setEvaluatable, updateAggregateMethods inherited from class org.h2.expression.Expression
addFilterConditions, getAlias, getBooleanValue, getColumnName, getColumnNameForView, getEnclosedSQL, getNonAliasExpression, getNullable, getSchemaName, getSQL, getSQL, getSQL, getSQL, getSubexpression, getSubexpressionCount, getTableAlias, getTableName, getWhenSQL, getWhenValue, isIdentity, isWhenConditionOperand, needParentheses, optimizeCondition, toString, writeExpressions, writeExpressionsMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.h2.util.HasSQL
getTraceSQL
-
Field Details
-
NULL
The expression represents ValueNull.INSTANCE. -
DEFAULT
This special expression represents the default value. It is used for UPDATE statements of the form SET COLUMN = DEFAULT. The value is ValueNull.INSTANCE, but should never be accessed. -
TRUE
The expression represents ValueBoolean.TRUE. -
FALSE
The expression represents ValueBoolean.FALSE.
-
-
Method Details
-
get
Create a new expression with the given value.- Parameters:
value- the value- Returns:
- the expression
-
getBoolean
Create a new expression with the given boolean value.- Parameters:
value- the boolean value- Returns:
- the expression
-
getBoolean
Create a new expression with the given boolean value.- Parameters:
value- the boolean value- Returns:
- the expression
-
getValue
Description copied from class:ExpressionReturn the resulting value for the current row.- Specified by:
getValuein classExpression- Parameters:
session- the session- Returns:
- the result
-
getType
Description copied from class:ExpressionReturns the data type. The data type may be unknown before the optimization phase.- Specified by:
getTypein interfaceTyped- Specified by:
getTypein classExpression- Returns:
- the data type
-
createIndexConditions
Description copied from class:ExpressionCreate index conditions if possible and attach them to the table filter.- Overrides:
createIndexConditionsin classExpression- Parameters:
session- the sessionfilter- the table filter
-
getNotIfPossible
Description copied from class:ExpressionIf it is possible, return the negated expression. This is used to optimize NOT expressions: NOT ID>10 can be converted to ID<=10. Returns null if negating is not possible.- Overrides:
getNotIfPossiblein classExpression- Parameters:
session- the session- Returns:
- the negated expression, or null
-
getTypeIfStaticallyKnown
Description copied from class:ExpressionReturns data type of this expression if it is statically known.- Overrides:
getTypeIfStaticallyKnownin classExpression- Parameters:
session- the session- Returns:
- data type or
null
-
isConstant
public boolean isConstant()Description copied from class:ExpressionCheck if this expression will always return the same value.- Overrides:
isConstantin classExpression- Returns:
- if the expression is constant
-
isNullConstant
public boolean isNullConstant()Description copied from class:ExpressionCheck if this expression will always return the NULL value.- Overrides:
isNullConstantin classExpression- Returns:
- if the expression is constant NULL value
-
isValueSet
public boolean isValueSet()Description copied from class:ExpressionIs the value of a parameter set.- Overrides:
isValueSetin classExpression- Returns:
- true if set
-
getUnenclosedSQL
Description copied from class:ExpressionGet the SQL statement of this expression. This may not always be the original SQL statement, especially after optimization. Enclosing '(' and ')' are never appended.- Specified by:
getUnenclosedSQLin classExpression- Parameters:
builder- string buildersqlFlags- formatting flags- Returns:
- the specified string builder
-
isEverything
Description copied from class:ExpressionCheck if this expression and all sub-expressions can fulfill a criteria. If any part returns false, the result is false.- Specified by:
isEverythingin classExpression- Parameters:
visitor- the visitor- Returns:
- if the criteria can be fulfilled
-
getCost
public int getCost()Description copied from class:ExpressionEstimate the cost to process the expression. Used when optimizing the query, to calculate the query plan with the lowest estimated cost.- Specified by:
getCostin classExpression- Returns:
- the estimated cost
-