Package org.apache.calcite.sql.type
Class LiteralOperandTypeChecker
- java.lang.Object
-
- org.apache.calcite.sql.type.LiteralOperandTypeChecker
-
- All Implemented Interfaces:
SqlOperandTypeChecker
,SqlSingleOperandTypeChecker
public class LiteralOperandTypeChecker extends java.lang.Object implements SqlSingleOperandTypeChecker
Parameter type-checking strategy type must be a literal (whether null is allowed is determined by the constructor).CAST(NULL as ...)
is considered to be a NULL literal but notCAST(CAST(NULL as ...) AS ...)
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.calcite.sql.type.SqlOperandTypeChecker
SqlOperandTypeChecker.Consistency
-
-
Field Summary
Fields Modifier and Type Field Description private boolean
allowNull
-
Constructor Summary
Constructors Constructor Description LiteralOperandTypeChecker(boolean allowNull)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
checkOperandTypes(SqlCallBinding callBinding, boolean throwOnFailure)
Checks the types of all operands to an operator call.boolean
checkSingleOperandType(SqlCallBinding callBinding, SqlNode node, int iFormalOperand, boolean throwOnFailure)
Checks the type of a single operand against a particular ordinal position within a formal operator signature.java.lang.String
getAllowedSignatures(SqlOperator op, java.lang.String opName)
Returns a string describing the allowed formal signatures of a call, e.g.SqlOperandTypeChecker.Consistency
getConsistency()
Returns the strategy for making the arguments have consistency types.SqlOperandCountRange
getOperandCountRange()
boolean
isOptional(int i)
Returns whether thei
th operand is optional.
-
-
-
Method Detail
-
isOptional
public boolean isOptional(int i)
Description copied from interface:SqlOperandTypeChecker
Returns whether thei
th operand is optional.- Specified by:
isOptional
in interfaceSqlOperandTypeChecker
-
checkSingleOperandType
public boolean checkSingleOperandType(SqlCallBinding callBinding, SqlNode node, int iFormalOperand, boolean throwOnFailure)
Description copied from interface:SqlSingleOperandTypeChecker
Checks the type of a single operand against a particular ordinal position within a formal operator signature. Note that the actual ordinal position of the operand being checked may be different from the position of the formal operand.For example, when validating the actual call
C(X, Y, Z)
the strategy for validating the operand Z might involve checking its type against the formal signature OP(W). In this case,
iFormalOperand
would be zero, even though the position of Z within call C is two.- Specified by:
checkSingleOperandType
in interfaceSqlSingleOperandTypeChecker
- Parameters:
callBinding
- description of the call being checked; this is only provided for context when throwing an exception; the implementation should NOT examine the operands of the call as part of the checknode
- the actual operand to be checkediFormalOperand
- the 0-based formal operand ordinalthrowOnFailure
- whether to throw an exception if check fails (otherwise returns false in that case)- Returns:
- whether check succeeded
-
checkOperandTypes
public boolean checkOperandTypes(SqlCallBinding callBinding, boolean throwOnFailure)
Description copied from interface:SqlOperandTypeChecker
Checks the types of all operands to an operator call.- Specified by:
checkOperandTypes
in interfaceSqlOperandTypeChecker
- Parameters:
callBinding
- description of the call to be checkedthrowOnFailure
- whether to throw an exception if check fails (otherwise returns false in that case)- Returns:
- whether check succeeded
-
getOperandCountRange
public SqlOperandCountRange getOperandCountRange()
- Specified by:
getOperandCountRange
in interfaceSqlOperandTypeChecker
- Returns:
- range of operand counts allowed in a call
-
getAllowedSignatures
public java.lang.String getAllowedSignatures(SqlOperator op, java.lang.String opName)
Description copied from interface:SqlOperandTypeChecker
Returns a string describing the allowed formal signatures of a call, e.g. "SUBSTR(VARCHAR, INTEGER, INTEGER)".- Specified by:
getAllowedSignatures
in interfaceSqlOperandTypeChecker
- Parameters:
op
- the operator being checkedopName
- name to use for the operator in case of aliasing- Returns:
- generated string
-
getConsistency
public SqlOperandTypeChecker.Consistency getConsistency()
Description copied from interface:SqlOperandTypeChecker
Returns the strategy for making the arguments have consistency types.- Specified by:
getConsistency
in interfaceSqlOperandTypeChecker
-
-