Class IsNode
- All Implemented Interfaces:
Visitable
-
Field Summary
FieldsFields inherited from class BinaryLogicalOperatorNode
shortCircuitValueFields inherited from class BinaryOperatorNode
AND, BinaryArgTypes, BinaryMethodNames, BinaryOperators, BinaryResultTypes, CONCATENATE, DIVIDE, EQ, GE, GT, K_BASE, K_XMLEXISTS, K_XMLQUERY, kind, LE, leftInterfaceType, leftOperand, LIKE, LT, methodName, MINUS, NE, operator, OR, PLUS, receiver, resultInterfaceType, rightInterfaceType, rightOperand, TIMESFields inherited from class ValueNode
transformedFields inherited from class QueryTreeNode
AUTOINCREMENT_CREATE_MODIFY, AUTOINCREMENT_CYCLE, AUTOINCREMENT_INC_INDEX, AUTOINCREMENT_IS_AUTOINCREMENT_INDEX, AUTOINCREMENT_START_INDEX -
Constructor Summary
ConstructorsConstructorDescriptionIsNode(ValueNode leftOperand, ValueNode rightOperand, boolean notMe, ContextManager cm) Constructor for an IsNode -
Method Summary
Modifier and TypeMethodDescription(package private) ValueNodebindExpression(FromList fromList, SubqueryList subqueryList, List<AggregateNode> aggregates) Bind this logical operator.changeToCNF(boolean underTopAndNode) Finish putting an expression into conjunctive normal form.(package private) ValueNodeeliminateNots(boolean underNotNode) Eliminate NotNodes in the current query block.(package private) voidDo code generation for this logical binary operator.Do the 1st step in putting child expressions into conjunctive normal form.booleanVerify that changeToCNF() did its job correctly.booleanVerify that putAndsOnTop() did its job correctly.Methods inherited from class BinaryLogicalOperatorNode
resolveLogicalBinaryOperator, verifyEliminateNotsMethods inherited from class BinaryOperatorNode
acceptChildren, bindXMLQuery, categorize, constantExpression, genSQLJavaSQLTree, getLeftOperand, getOrderableVariantType, getReceiverInterfaceName, getRightOperand, isConstantExpression, isEquivalent, isSameNodeKind, preprocess, printSubNodes, remapColumnReferencesToExpressions, setLeftOperand, setLeftRightInterfaceType, setMethodName, setOperator, setRightOperand, toStringMethods inherited from class OperatorNode
pushSqlXmlUtilMethods inherited from class ValueNode
bindExpression, checkIsBoolean, checkTopPredicatesForEqualsConditions, copyFields, evaluateConstantExpressions, genEqualsFalseTree, generate, genIsNullTree, getClone, getColumnName, getConstantValueAsObject, getDataValueFactory, getSchemaName, getSourceResultColumn, getTableName, getTablesReferenced, getTransformed, getTypeCompiler, getTypeId, getTypeServices, isBinaryEqualsOperatorNode, isBooleanFalse, isBooleanTrue, isCloneable, isInListProbeNode, isParameterNode, isRelationalOperator, optimizableEqualityNode, requiresTypeFromContext, selectivity, setCollationInfo, setCollationInfo, setCollationUsingCompilationSchema, setCollationUsingCompilationSchema, setNullability, setTransformed, setType, setType, setType, updatableByCursorMethods inherited from class QueryTreeNode
accept, addTag, addUDTUsagePriv, addUDTUsagePriv, bindOffsetFetch, bindRowMultiSet, bindUserCatalogType, bindUserType, checkReliability, checkReliability, convertDefaultNode, copyTagsFrom, createTypeDependency, debugFlush, debugPrint, disablePrivilegeCollection, formatNodeString, generateAuthorizeCheck, getBeginOffset, getClassFactory, getCompilerContext, getContext, getContextManager, getDataDictionary, getDependencyManager, getEndOffset, getExecutionFactory, getGenericConstantActionFactory, getIntProperty, getLanguageConnectionContext, getLongProperty, getNullNode, getOffsetOrderedNodes, getOptimizerFactory, getOptimizerTracer, getParameterTypes, getSchemaDescriptor, getSchemaDescriptor, getStatementType, getTableDescriptor, getTypeCompiler, getUDTDesc, isAtomic, isPrivilegeCollectionRequired, isSessionSchema, isSessionSchema, makeConstantAction, makeTableName, makeTableName, nodeHeader, optimizerTracingIsOn, orReliability, parseSearchCondition, parseStatement, printLabel, referencesSessionSchema, resolveTableToSynonym, setBeginOffset, setEndOffset, setRefActionInfo, stackPrint, taggedWith, treePrint, treePrint, verifyClassExist
-
Field Details
-
notMe
private boolean notMe
-
-
Constructor Details
-
IsNode
IsNode(ValueNode leftOperand, ValueNode rightOperand, boolean notMe, ContextManager cm) Constructor for an IsNode- Parameters:
leftOperand- The left operand of the ISrightOperand- The right operand of the ISnotMe- Whether to reverse the sense of this node.cm- The context manager
-
-
Method Details
-
bindExpression
ValueNode bindExpression(FromList fromList, SubqueryList subqueryList, List<AggregateNode> aggregates) throws StandardException Bind this logical operator. All that has to be done for binding a logical operator is to bind the operands, check that both operands are BooleanDataValue, and set the result type to BooleanDataValue.- Overrides:
bindExpressionin classBinaryLogicalOperatorNode- Parameters:
fromList- The query's FROM listsubqueryList- The subquery list being built as we find SubqueryNodesaggregates- The aggregate list being built as we find AggregateNodes- Returns:
- The new top of the expression tree.
- Throws:
StandardException- Thrown on error
-
eliminateNots
Eliminate NotNodes in the current query block. We just mark whether this IS node is under an eliminated NOT node.- Overrides:
eliminateNotsin classValueNode- Parameters:
underNotNode- Whether or not we are under a NotNode.- Returns:
- The modified expression
- Throws:
StandardException- Thrown on error
-
putAndsOnTop
Do the 1st step in putting child expressions into conjunctive normal form. This step ensures that the top level of the child expression is a chain of AndNodes terminated by a true BooleanConstantNode.- Overrides:
putAndsOnTopin classValueNode- Returns:
- The modified expression
- Throws:
StandardException- Thrown on error
-
verifyPutAndsOnTop
public boolean verifyPutAndsOnTop()Verify that putAndsOnTop() did its job correctly. Verify that the top level of the expression is a chain of AndNodes terminated by a true BooleanConstantNode.- Overrides:
verifyPutAndsOnTopin classValueNode- Returns:
- Boolean which reflects validity of the tree.
-
changeToCNF
Finish putting an expression into conjunctive normal form. An expression tree in conjunctive normal form meets the following criteria: o If the expression tree is not null, the top level will be a chain of AndNodes terminating in a true BooleanConstantNode. o The left child of an AndNode will never be an AndNode. o Any right-linked chain that includes an AndNode will be entirely composed of AndNodes terminated by a true BooleanConstantNode. o The left child of an OrNode will never be an OrNode. o Any right-linked chain that includes an OrNode will be entirely composed of OrNodes terminated by a false BooleanConstantNode. o ValueNodes other than AndNodes and OrNodes are considered leaf nodes for purposes of expression normalization. In other words, we won't do any normalization under those nodes. In addition, we track whether or not we are under a top level AndNode. SubqueryNodes need to know this for subquery flattening.- Overrides:
changeToCNFin classValueNode- Parameters:
underTopAndNode- Whether or not we are under a top level AndNode.- Returns:
- The modified expression
- Throws:
StandardException- Thrown on error
-
verifyChangeToCNF
public boolean verifyChangeToCNF()Verify that changeToCNF() did its job correctly. Verify that: o AndNode - rightOperand is not instanceof OrNode leftOperand is not instanceof AndNode o OrNode - rightOperand is not instanceof AndNode leftOperand is not instanceof OrNode- Overrides:
verifyChangeToCNFin classValueNode- Returns:
- Boolean which reflects validity of the tree.
-
generateExpression
Do code generation for this logical binary operator.- Overrides:
generateExpressionin classBinaryLogicalOperatorNode- Parameters:
acb- The ExpressionClassBuilder for the class we're generatingmb- the method the expression will go into- Throws:
StandardException- Thrown on error
-