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

com.alibaba.druid.support.opds.udf.ExportTables Maven / Gradle / Ivy

There is a newer version: 1.2.24
Show newest version
/*
 * Copyright 1999-2017 Alibaba Group Holding Ltd.
 *
 * Licensed 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.alibaba.druid.support.opds.udf;

import com.alibaba.druid.DbType;
import com.alibaba.druid.sql.SQLUtils;
import com.alibaba.druid.sql.ast.SQLStatement;
import com.alibaba.druid.sql.visitor.SchemaStatVisitor;
import com.alibaba.druid.stat.TableStat;
import com.aliyun.odps.udf.UDF;

import java.util.List;
import java.util.Map;

public class ExportTables extends UDF {
    public String evaluate(String sql) throws Throwable {
        return evaluate(sql, null, false);
    }

    public String evaluate(String sql, String dbTypeName) throws Throwable {
        return evaluate(sql, dbTypeName, false);
    }

    public String evaluate(String sql, String dbTypeName, boolean throwError) throws Throwable {
        DbType dbType = dbTypeName == null ? null : DbType.valueOf(dbTypeName);

        Throwable error = null;
        try {
            List statementList = SQLUtils.parseStatements(sql, dbType);
            SchemaStatVisitor visitor = SQLUtils.createSchemaStatVisitor(dbType);

            for (SQLStatement stmt : statementList) {
                stmt.accept(visitor);
            }

            StringBuffer buf = new StringBuffer();

            for (Map.Entry entry : visitor.getTables().entrySet()) {
                TableStat.Name name = entry.getKey();

                if (buf.length() != 0) {
                    buf.append(',');
                }
                buf.append(name.toString());
            }

            return buf.toString();
        } catch (Exception ignored) {
            // skip
        } catch (StackOverflowError ignored) {
            // skip
        }

        if (throwError && error != null) {
            throw error;
        }

        return null;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy