Interface SqlSingleOperandTypeChecker
- All Superinterfaces:
SqlOperandTypeChecker
- All Known Implementing Classes:
ArrayInsertOperandTypeChecker,ComparableOperandTypeChecker,CompositeSingleOperandTypeChecker,FamilyOperandTypeChecker,IntervalOperandTypeChecker,LiteralOperandTypeChecker,NotNullOperandTypeChecker,OperandMetadataImpl,SameOperandTypeChecker,SameOperandTypeExceptLastOperandChecker
SqlOperandTypeChecker
for implementations which are capable of checking the type of a single
operand in isolation. This isn't meaningful for all type-checking rules (e.g.
SameOperandTypeChecker requires two operands to have matching types, so
checking one in isolation is meaningless).-
Nested Class Summary
Nested classes/interfaces inherited from interface org.apache.calcite.sql.type.SqlOperandTypeChecker
SqlOperandTypeChecker.Consistency -
Method Summary
Modifier and TypeMethodDescriptiondefault SqlSingleOperandTypeCheckerand(SqlSingleOperandTypeChecker checker) Composes this with another single-operand checker using AND.default booleancheckOperandTypes(SqlCallBinding callBinding, boolean throwOnFailure) Checks the types of all operands to an operator call.booleancheckSingleOperandType(SqlCallBinding callBinding, SqlNode operand, int iFormalOperand, boolean throwOnFailure) Checks the type of a single operand against a particular ordinal position within a formal operator signature.default SqlOperandCountRangeReturns the range of operand counts allowed in a call.default SqlSingleOperandTypeCheckeror(SqlSingleOperandTypeChecker checker) Composes this with another single-operand checker using OR.Methods inherited from interface org.apache.calcite.sql.type.SqlOperandTypeChecker
and, getAllowedSignatures, getConsistency, isFixedParameters, isOptional, or, typeInference, withGenerator
-
Method Details
-
checkSingleOperandType
boolean checkSingleOperandType(SqlCallBinding callBinding, SqlNode operand, int iFormalOperand, boolean throwOnFailure) 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,
iFormalOperandwould be zero, even though the position of Z within call C is two.Caution that we could not(shouldn't) implement implicit type coercion for this checker, implicit type coercion has side effect(modify the AST), if this single operand checker is subsumed in a composite rule(OR or AND), we can not make any side effect if we can not make sure that all the single operands type check are passed(with type coercion). But there is an exception: only if the call has just one operand, for this case, use
SqlOperandTypeChecker.checkOperandTypes(org.apache.calcite.sql.SqlCallBinding, boolean)instead.- 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 checkoperand- 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
Description copied from interface:SqlOperandTypeCheckerChecks the types of all operands to an operator call.- Specified by:
checkOperandTypesin 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
Description copied from interface:SqlOperandTypeCheckerReturns the range of operand counts allowed in a call.- Specified by:
getOperandCountRangein interfaceSqlOperandTypeChecker
-
and
Composes this with another single-operand checker using AND. -
or
Composes this with another single-operand checker using OR.
-