public class WithNamespace extends Object
WITH clause.| Modifier and Type | Field and Description |
|---|---|
protected SqlNode |
enclosingNode |
protected RelDataType |
rowType
Type of the output row, which comprises the name and type of each output
column.
|
protected RelDataType |
type
As
rowType, but not necessarily a struct. |
protected SqlValidatorImpl |
validator |
| Modifier and Type | Method and Description |
|---|---|
protected RelDataType |
convertToStruct(RelDataType type) |
boolean |
fieldExists(String name)
Returns whether this namespace has a field of a given name.
|
SqlNode |
getEnclosingNode()
Returns the parse tree node that at is at the root of this namespace and
includes all decorations.
|
List<Pair<SqlNode,SqlMonotonicity>> |
getMonotonicExprs()
Returns a list of expressions which are monotonic in this namespace.
|
SqlMonotonicity |
getMonotonicity(String columnName)
Returns whether and how a given column is sorted.
|
SqlNode |
getNode()
Returns the parse tree node at the root of this namespace.
|
RelDataType |
getRowType()
Returns the row type of this namespace, which comprises a list of names
and types of the output columns.
|
RelDataType |
getRowTypeSansSystemColumns()
Returns the row type of this namespace, sans any system columns.
|
SqlValidatorTable |
getTable()
Returns the underlying table, or null if there is none.
|
RelDataType |
getType()
Returns the type of this namespace.
|
SqlValidator |
getValidator()
Returns the validator.
|
boolean |
isWrapperFor(Class<?> clazz)
Returns whether this namespace implements a given interface, or wraps a
class which does.
|
SqlValidatorNamespace |
lookupChild(String name)
Looks up a child namespace of a given name.
|
void |
makeNullable()
Makes all fields in this namespace nullable (typically because it is on
the outer side of an outer join.
|
SqlValidatorNamespace |
resolve()
If this namespace resolves to another namespace, returns that namespace,
following links to the end of the chain.
|
void |
setType(RelDataType type)
Sets the type of this namespace.
|
boolean |
supportsModality(SqlModality modality)
Returns whether this namespace is capable of giving results of the desired
modality.
|
String |
translate(String name)
Translates a field name to the name in the underlying namespace.
|
<T> T |
unwrap(Class<T> clazz)
Returns this namespace, or a wrapped namespace, cast to a particular
class.
|
void |
validate()
Validates this namespace.
|
protected RelDataType |
validateImpl()
Validates this scope and returns the type of the records it returns.
|
protected final SqlValidatorImpl validator
protected RelDataType rowType
protected RelDataType type
rowType, but not necessarily a struct.protected final SqlNode enclosingNode
protected RelDataType validateImpl()
validate(), which uses the
status field to protect against cycles.public SqlNode getNode()
SqlValidatorNamespaceTableNamespacepublic SqlValidator getValidator()
SqlValidatorNamespacegetValidator in interface SqlValidatorNamespacepublic final void validate()
SqlValidatorNamespaceIf the scope has already been validated, does nothing.
Please call SqlValidatorImpl.validateNamespace(org.apache.calcite.sql.validate.SqlValidatorNamespace) rather than
calling this method directly.
validate in interface SqlValidatorNamespacepublic RelDataType getRowType()
SqlValidatorNamespacegetRowType in interface SqlValidatorNamespacepublic RelDataType getRowTypeSansSystemColumns()
SqlValidatorNamespacegetRowTypeSansSystemColumns in interface SqlValidatorNamespacepublic RelDataType getType()
SqlValidatorNamespacegetType in interface SqlValidatorNamespacepublic void setType(RelDataType type)
SqlValidatorNamespaceAllows the type for the namespace to be explicitly set, but usually is
called during SqlValidatorNamespace.validate().
Implicitly also sets the row type. If the type is not a struct, then the row type is the type wrapped as a struct with a single column, otherwise the type and row type are the same.
setType in interface SqlValidatorNamespacepublic SqlNode getEnclosingNode()
SqlValidatorNamespaceSqlValidatorNamespace.getNode().getEnclosingNode in interface SqlValidatorNamespacepublic SqlValidatorTable getTable()
SqlValidatorNamespacegetTable in interface SqlValidatorNamespacepublic SqlValidatorNamespace lookupChild(String name)
SqlValidatorNamespaceFor example, in the query select e.name from emps as e,
e is an IdentifierNamespace which has a child
name which is a FieldNamespace.
lookupChild in interface SqlValidatorNamespacename - Name of namespacepublic boolean fieldExists(String name)
SqlValidatorNamespacefieldExists in interface SqlValidatorNamespacename - Field namepublic List<Pair<SqlNode,SqlMonotonicity>> getMonotonicExprs()
SqlValidatorNamespaceSqlIdentifier called "TIMESTAMP".getMonotonicExprs in interface SqlValidatorNamespacepublic SqlMonotonicity getMonotonicity(String columnName)
SqlValidatorNamespacegetMonotonicity in interface SqlValidatorNamespacepublic void makeNullable()
SqlValidatorNamespacemakeNullable in interface SqlValidatorNamespacepublic String translate(String name)
SqlValidatorNamespacetranslate in interface SqlValidatorNamespacepublic SqlValidatorNamespace resolve()
SqlValidatorNamespaceA WITH) clause defines table names that resolve to queries
(the body of the with-item). An IdentifierNamespace typically
resolves to a TableNamespace.
You must not call this method before SqlValidatorNamespace.validate() has
completed.
resolve in interface SqlValidatorNamespacepublic boolean supportsModality(SqlModality modality)
SqlValidatorNamespacetrue means streaming, false means relational.supportsModality in interface SqlValidatorNamespacemodality - Modalitypublic <T> T unwrap(Class<T> clazz)
SqlValidatorNamespaceunwrap in interface SqlValidatorNamespaceclazz - Desired typepublic boolean isWrapperFor(Class<?> clazz)
SqlValidatorNamespaceisWrapperFor in interface SqlValidatorNamespaceclazz - Interfaceprotected RelDataType convertToStruct(RelDataType type)
Copyright © 2012–2015 The Apache Software Foundation. All rights reserved.