All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.org.apache.calcite.sql.validate.SelectScope Maven / Gradle / Ivy

There is a newer version: 5.5.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.hazelcast.org.apache.calcite.sql.validate;

import com.hazelcast.org.apache.calcite.sql.SqlCall;
import com.hazelcast.org.apache.calcite.sql.SqlIdentifier;
import com.hazelcast.org.apache.calcite.sql.SqlNode;
import com.hazelcast.org.apache.calcite.sql.SqlNodeList;
import com.hazelcast.org.apache.calcite.sql.SqlSelect;
import com.hazelcast.org.apache.calcite.sql.SqlWindow;
import com.hazelcast.org.apache.calcite.sql.fun.SqlStdOperatorTable;
import com.hazelcast.org.apache.calcite.sql.parser.SqlParserPos;
import com.hazelcast.org.apache.calcite.util.Litmus;
import com.hazelcast.org.apache.calcite.util.Pair;

import com.hazelcast.org.checkerframework.checker.nullness.qual.MonotonicNonNull;
import com.hazelcast.org.checkerframework.checker.nullness.qual.Nullable;

import java.util.ArrayList;
import java.util.List;
import java.util.Objects;

/**
 * The name-resolution scope of a SELECT clause. The objects visible are those
 * in the FROM clause, and objects inherited from the parent scope.
 *
 *
 * 

This object is both a {@link SqlValidatorScope} and a * {@link SqlValidatorNamespace}. In the query

* *
*
SELECT name FROM (
 *     SELECT *
 *     FROM emp
 *     WHERE gender = 'F')
* *

we need to use the {@link SelectScope} as a * {@link SqlValidatorNamespace} when resolving 'name', and * as a {@link SqlValidatorScope} when resolving 'gender'.

* *

Scopes

* *

In the query

* *
*
 * SELECT expr1
 * FROM t1,
 *     t2,
 *     (SELECT expr2 FROM t3) AS q3
 * WHERE c1 IN (SELECT expr3 FROM t4)
 * ORDER BY expr4
*
* *

The scopes available at various points of the query are as follows:

* *
    *
  • expr1 can see t1, t2, q3
  • *
  • expr2 can see t3
  • *
  • expr3 can see t4, t1, t2
  • *
  • expr4 can see t1, t2, q3, plus (depending upon the dialect) any aliases * defined in the SELECT clause
  • *
* *

Namespaces

* *

In the above query, there are 4 namespaces:

* *
    *
  • t1
  • *
  • t2
  • *
  • (SELECT expr2 FROM t3) AS q3
  • *
  • (SELECT expr3 FROM t4)
  • *
* * @see SelectNamespace */ public class SelectScope extends ListScope { //~ Instance fields -------------------------------------------------------- private final SqlSelect select; protected final List windowNames = new ArrayList<>(); private @Nullable List expandedSelectList = null; /** * List of column names which sort this scope. Empty if this scope is not * sorted. Null if has not been computed yet. */ private @MonotonicNonNull SqlNodeList orderList; /** Scope to use to resolve windows. */ private final @Nullable SqlValidatorScope windowParent; //~ Constructors ----------------------------------------------------------- /** * Creates a scope corresponding to a SELECT clause. * * @param parent Parent scope, must not be null * @param winParent Scope for window parent, may be null * @param select Select clause */ SelectScope( SqlValidatorScope parent, @Nullable SqlValidatorScope winParent, SqlSelect select) { super(parent); this.select = select; this.windowParent = winParent; } //~ Methods ---------------------------------------------------------------- public @Nullable SqlValidatorTable getTable() { return null; } @Override public SqlSelect getNode() { return select; } @Override public @Nullable SqlWindow lookupWindow(String name) { final SqlNodeList windowList = select.getWindowList(); for (int i = 0; i < windowList.size(); i++) { SqlWindow window = (SqlWindow) windowList.get(i); final SqlIdentifier declId = Objects.requireNonNull( window.getDeclName(), () -> "declName of window " + window); assert declId.isSimple(); if (declId.names.get(0).equals(name)) { return window; } } // if not in the select scope, then check window scope if (windowParent != null) { return windowParent.lookupWindow(name); } else { return null; } } @Override public SqlMonotonicity getMonotonicity(SqlNode expr) { SqlMonotonicity monotonicity = expr.getMonotonicity(this); if (monotonicity != SqlMonotonicity.NOT_MONOTONIC) { return monotonicity; } // TODO: compare fully qualified names final SqlNodeList orderList = getOrderList(); if (orderList.size() > 0) { SqlNode order0 = orderList.get(0); monotonicity = SqlMonotonicity.INCREASING; if ((order0 instanceof SqlCall) && (((SqlCall) order0).getOperator() == SqlStdOperatorTable.DESC)) { monotonicity = monotonicity.reverse(); order0 = ((SqlCall) order0).operand(0); } if (expr.equalsDeep(order0, Litmus.IGNORE)) { return monotonicity; } } return SqlMonotonicity.NOT_MONOTONIC; } @Override public SqlNodeList getOrderList() { if (orderList == null) { // Compute on demand first call. orderList = new SqlNodeList(SqlParserPos.ZERO); if (children.size() == 1) { final SqlValidatorNamespace child = children.get(0).namespace; final List> monotonicExprs = child.getMonotonicExprs(); if (monotonicExprs.size() > 0) { orderList.add(monotonicExprs.get(0).left); } } } return orderList; } public void addWindowName(String winName) { windowNames.add(winName); } public boolean existingWindowName(String winName) { for (String windowName : windowNames) { if (windowName.equalsIgnoreCase(winName)) { return true; } } // if the name wasn't found then check the parent(s) SqlValidatorScope walker = parent; while (!(walker instanceof EmptyScope)) { if (walker instanceof SelectScope) { final SelectScope parentScope = (SelectScope) walker; return parentScope.existingWindowName(winName); } walker = ((DelegatingScope) walker).parent; } return false; } public @Nullable List getExpandedSelectList() { return expandedSelectList; } public void setExpandedSelectList(@Nullable List selectList) { expandedSelectList = selectList; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy