• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

Java SqlShuttle类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中org.apache.calcite.sql.util.SqlShuttle的典型用法代码示例。如果您正苦于以下问题:Java SqlShuttle类的具体用法?Java SqlShuttle怎么用?Java SqlShuttle使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



SqlShuttle类属于org.apache.calcite.sql.util包,在下文中一共展示了SqlShuttle类的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: checkSelectPrivilegeThrow

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
private void checkSelectPrivilegeThrow(SqlNode query) throws PostgresException {
    final PostgresException[] e = {null};

    query.accept(new SqlShuttle() {
        @Override
        public SqlNode visit(SqlIdentifier identifier) {
            if (identifier.names.size() == 3 && e[0] == null) {
                String[] schemaName = {identifier.names.get(0), identifier.names.get(1)};
                e[0] = checkObjectPrivilegeInternal(ObjectPrivilege.SELECT, schemaName);
            }
            return identifier;
        }
    });

    if (e[0] != null)
        throw e[0];
}
 
开发者ID:bitnine-oss,项目名称:octopus,代码行数:18,代码来源:QueryEngine.java


示例2: stripNamespace

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
/**
 * Strips namespace from identifiers of sql
 *
 * @param node
 * @param namespace
 * @param dialect
 * @return
 */
private String stripNamespace(final SqlNode node,
                              final String namespace,
                              final SqlDialect dialect) {
  final SqlNode transformedNode = node.accept(
      new SqlShuttle() {
        @Override
        public SqlNode visit(SqlIdentifier id) {
          if (id.names.size() > 1
              && id.names.get(0).toUpperCase().equals(namespace.toUpperCase())) {
            return id.getComponent(1, id.names.size());
          } else {
            return id;
          }
        }
      });
  String result = transformedNode.toSqlString(dialect).toString();
  return result.replace("\n", " ");
}
 
开发者ID:qubole,项目名称:quark,代码行数:27,代码来源:SqlQueryParser.java


示例3: getDatasourceNames

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
private List<String> getDatasourceNames(SqlNode query) {
    final Set<String> dsSet = new HashSet<>();
    query.accept(new SqlShuttle() {
        @Override
        public SqlNode visit(SqlIdentifier identifier) {
            // check whether this is fully qualified table name
            if (identifier.names.size() == 3) {
                dsSet.add(identifier.names.get(0));
            }
            return identifier;
        }
    });

    return new ArrayList<>(dsSet);
}
 
开发者ID:bitnine-oss,项目名称:octopus,代码行数:16,代码来源:QueryEngine.java


示例4: CursorHive

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
public CursorHive(CachedStatement cachedStatement, String name,
                  FormatCode[] paramFormats, byte[][] paramValues,
                  FormatCode[] resultFormats, String dataSourceName) {
    super(cachedStatement, name, paramFormats, paramValues, resultFormats);

    sessionId = Session.currentSession().getId();
    this.dataSourceName = dataSourceName;

    /*
     * NOTE: Deep-copy validatedQuery because TableNameTranslator.toDSN()
     *       changes identifiers of validatedQuery itself.
     *       When this Portal runs again without copied one,
     *       the by-pass test in processBind() which uses the validatedQuery
     *       will produce an error.
     *       To reduce number of copies, cache queryString.
     */
    CachedStatement cStmt = (CachedStatement) getCachedQuery();
    SqlNode cloned = cStmt.getValidatedQuery().accept(new SqlShuttle() {
        @Override
        public SqlNode visit(SqlIdentifier id) {
            return id.clone(id.getParserPosition());
        }
    });
    TableNameTranslator.toDSN(cloned);
    SqlDialect.DatabaseProduct dp = SqlDialect.DatabaseProduct.HIVE;
    queryString = cloned.toSqlString(dp.getDialect()).getSql();
}
 
开发者ID:bitnine-oss,项目名称:octopus,代码行数:28,代码来源:CursorHive.java


示例5: result

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
/**
 * Creates a result based on a single relational expression.
 */
public Result result(SqlNode node, Collection<Clause> clauses, RelNode rel) {
    System.out.println("******************************************************");
    System.out.println("******************************************************");
    System.out.println("******************************************************");
    System.out.println("******************************************************");
    System.out.println(node.toString());
    SqlNode cloned = node.accept(new SqlShuttle() {
        @Override
        public SqlNode visit(SqlIdentifier id) {
            return id.clone(id.getParserPosition());
        }
    });
    //TableNameTranslator.toDSN(cloned);
    if (cloned instanceof SqlIdentifier) {
        List<String> dsn = new ArrayList<>();
        SqlIdentifier tableId = (SqlIdentifier) cloned;
        String schemaName = tableId.names.get(1);
        if (!"__DEFAULT".equals(schemaName))
            dsn.add(schemaName);
        dsn.add(tableId.names.get(2));
        tableId.setNames(dsn, null);
    }
    System.out.println(cloned.toString());

    final String alias2 = SqlValidatorUtil.getAlias(node, -1);
    final String alias3 = alias2 != null ? alias2 : "t";
    final String alias4 =
            SqlValidatorUtil.uniquify(
                    alias3, aliasSet, SqlValidatorUtil.EXPR_SUGGESTER);
    final String alias5 = alias2 == null || !alias2.equals(alias4) ? alias4
            : null;
    return new Result(cloned, clauses, alias5,
            Collections.singletonList(Pair.of(alias4, rel.getRowType())));
}
 
开发者ID:bitnine-oss,项目名称:octopus,代码行数:38,代码来源:JdbcImplementor.java


示例6: getParameterRowType

import org.apache.calcite.sql.util.SqlShuttle; //导入依赖的package包/类
public RelDataType getParameterRowType(SqlNode sqlQuery) {
  // NOTE: We assume that bind variables occur in depth-first tree
  // traversal in the same order that they occurred in the SQL text.
  final List<RelDataType> types = new ArrayList<>();
  // NOTE: but parameters on fetch/offset would be counted twice
  // as they are counted in the SqlOrderBy call and the inner SqlSelect call
  final Set<SqlNode> alreadyVisited = new HashSet<>();
  sqlQuery.accept(
      new SqlShuttle() {

        @Override public SqlNode visit(SqlDynamicParam param) {
          if (alreadyVisited.add(param)) {
            RelDataType type = getValidatedNodeType(param);
            types.add(type);
          }
          return param;
        }
      });
  return typeFactory.createStructType(
      types,
      new AbstractList<String>() {
        @Override public String get(int index) {
          return "?" + index;
        }

        @Override public int size() {
          return types.size();
        }
      });
}
 
开发者ID:apache,项目名称:calcite,代码行数:31,代码来源:SqlValidatorImpl.java



注:本文中的org.apache.calcite.sql.util.SqlShuttle类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java JMVCommandEvent类代码示例发布时间:2022-05-23
下一篇:
Java UpnpOutputArgument类代码示例发布时间:2022-05-23
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap