public class Operation extends Expression
Modifier and Type | Field and Description |
---|---|
static int |
CONCAT
This operation represents a string concatenation as in 'Hello' || 'World'.
|
static int |
DIVIDE
This operation represents a division as in 4 * 2.
|
static int |
MINUS
This operation represents a subtraction as in 2 - 1.
|
static int |
MODULUS
This operation represents a modulus as in 5 % 2.
|
static int |
MULTIPLY
This operation represents a multiplication as in 2 * 3.
|
static int |
NEGATE
This operation represents a negation as in - ID.
|
static int |
PLUS
This operation represents an addition as in 1 + 2.
|
Constructor and Description |
---|
Operation(int opType,
Expression left,
Expression right) |
Modifier and Type | Method and Description |
---|---|
int |
getCost()
Estimate the cost to process the expression.
|
int |
getDisplaySize()
Get the display size of this expression.
|
long |
getPrecision()
Get the precision of this expression.
|
int |
getScale()
Get the scale of this expression.
|
String |
getSQL()
Get the SQL statement of this expression.
|
int |
getType()
Return the data type.
|
Value |
getValue(Session session)
Return the resulting value for the current row.
|
boolean |
isEverything(ExpressionVisitor visitor)
Check if this expression and all sub-expressions can fulfill a criteria.
|
void |
mapColumns(ColumnResolver resolver,
int level)
Map the columns of the resolver to expression columns.
|
Expression |
optimize(Session session)
Try to optimize the expression.
|
void |
setEvaluatable(TableFilter tableFilter,
boolean b)
Tell the expression columns whether the table filter can return values now.
|
void |
updateAggregate(Session session)
Update an aggregate value.
|
addFilterConditions, createIndexConditions, getAlias, getBooleanValue, getColumnName, getExpressionColumns, getExpressionColumns, getNonAliasExpression, getNotIfPossible, getNullable, getSchemaName, getTableAlias, getTableName, isAutoIncrement, isConstant, isValueSet, isWildcard, toString
public static final int CONCAT
public static final int PLUS
public static final int MINUS
public static final int MULTIPLY
public static final int DIVIDE
public static final int NEGATE
public static final int MODULUS
public Operation(int opType, Expression left, Expression right)
public String getSQL()
Expression
getSQL
in class Expression
public Value getValue(Session session)
Expression
getValue
in class Expression
session
- the sessionpublic void mapColumns(ColumnResolver resolver, int level)
Expression
mapColumns
in class Expression
resolver
- the column resolverlevel
- the subquery nesting levelpublic Expression optimize(Session session)
Expression
optimize
in class Expression
session
- the sessionpublic void setEvaluatable(TableFilter tableFilter, boolean b)
Expression
setEvaluatable
in class Expression
tableFilter
- the table filterb
- true if the table filter can return valuepublic int getType()
Expression
getType
in class Expression
public long getPrecision()
Expression
getPrecision
in class Expression
public int getDisplaySize()
Expression
getDisplaySize
in class Expression
public int getScale()
Expression
getScale
in class Expression
public void updateAggregate(Session session)
Expression
updateAggregate
in class Expression
session
- the sessionpublic boolean isEverything(ExpressionVisitor visitor)
Expression
isEverything
in class Expression
visitor
- the visitorpublic int getCost()
Expression
getCost
in class Expression
Copyright © 2012 JBoss by Red Hat. All Rights Reserved.