Impala
Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
TableAliasGenerator.java
Go to the documentation of this file.
1 // Copyright 2014 Cloudera Inc.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 package com.cloudera.impala.common;
16 
18 
19 import com.google.common.base.Preconditions;
20 
21 public class TableAliasGenerator extends AliasGenerator {
22  private static final String DEFAULT_TBL_ALIAS_PREFIX = "$a$";
23 
24  public TableAliasGenerator(Analyzer analyzer, String prefix) {
25  Preconditions.checkNotNull(analyzer);
26  aliasPrefix_ = prefix != null ? prefix : DEFAULT_TBL_ALIAS_PREFIX;
27  Analyzer currentAnalyzer = analyzer;
28  do {
29  usedAliases_.addAll(currentAnalyzer.getAliases());
30  usedAliases_.addAll(currentAnalyzer.getLocalViews().keySet());
31  currentAnalyzer = currentAnalyzer.getParentAnalyzer();
32  } while (currentAnalyzer != null);
33  }
34 }
TableAliasGenerator(Analyzer analyzer, String prefix)