Package org.apache.calcite.sql.fun
Class SqlCase
java.lang.Object
org.apache.calcite.sql.SqlNode
org.apache.calcite.sql.SqlCall
org.apache.calcite.sql.fun.SqlCase
- All Implemented Interfaces:
Cloneable
A
SqlCase
is a node of a parse tree which represents a case
statement. It warrants its own node type just because we have a lot of
methods to put somewhere.-
Field Summary
Fields inherited from class org.apache.calcite.sql.SqlNode
EMPTY_ARRAY, pos
-
Constructor Summary
ConstructorDescriptionSqlCase
(SqlParserPos pos, @Nullable SqlNode value, SqlNodeList whenList, SqlNodeList thenList, @Nullable SqlNode elseExpr) Creates a SqlCase expression. -
Method Summary
Modifier and TypeMethodDescriptionstatic SqlCase
createSwitched
(SqlParserPos pos, @Nullable SqlNode value, SqlNodeList whenList, SqlNodeList thenList, @Nullable SqlNode elseClause) Creates a call to the switched form of the CASE operator.@Nullable SqlNode
getKind()
Returns the type of node this is, orSqlKind.OTHER
if it's nothing special.Returns the list of operands.@Nullable SqlNode
void
setOperand
(int i, @Nullable SqlNode operand) Changes the value of an operand.Methods inherited from class org.apache.calcite.sql.SqlCall
accept, clone, equalsDeep, findValidOptions, getCallSignature, getFunctionQuantifier, getMonotonicity, isCountStar, isExpanded, operand, operandCount, unparse, validate
Methods inherited from class org.apache.calcite.sql.SqlNode
clone, clone, cloneArray, equalDeep, equalDeep, equalsDeep, getParserPosition, isA, toList, toList, toSqlString, toSqlString, toSqlString, toString, unparseWithParentheses, validateExpr
-
Constructor Details
-
SqlCase
public SqlCase(SqlParserPos pos, @Nullable SqlNode value, SqlNodeList whenList, SqlNodeList thenList, @Nullable SqlNode elseExpr) Creates a SqlCase expression.- Parameters:
pos
- Parser positionvalue
- The value (null for boolean case)whenList
- List of all WHEN expressionsthenList
- List of all THEN expressionselseExpr
- The implicit or explicit ELSE expression
-
-
Method Details
-
createSwitched
public static SqlCase createSwitched(SqlParserPos pos, @Nullable SqlNode value, SqlNodeList whenList, SqlNodeList thenList, @Nullable SqlNode elseClause) Creates a call to the switched form of the CASE operator. For example:CASE value
WHEN whenList[0] THEN thenList[0]
WHEN whenList[1] THEN thenList[1]
...
ELSE elseClause
END -
getKind
Description copied from class:SqlNode
Returns the type of node this is, orSqlKind.OTHER
if it's nothing special. -
getOperator
- Specified by:
getOperator
in classSqlCall
-
getOperandList
Description copied from class:SqlCall
Returns the list of operands. The set and order of operands is call-specific.Note: the proper type would be
List<@Nullable SqlNode>
, however, it would trigger too many changes to the current codebase.- Specified by:
getOperandList
in classSqlCall
- Returns:
- the list of call operands, never null, the operands can be null
-
setOperand
Description copied from class:SqlCall
Changes the value of an operand. Allows some rewrite bySqlValidator
; use sparingly.- Overrides:
setOperand
in classSqlCall
- Parameters:
i
- Operand indexoperand
- Operand value
-
getValueOperand
-
getWhenOperands
-
getThenOperands
-
getElseOperand
-