org.verdictdb.connection.CachedMetaDataProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of verdictdb-core Show documentation
Show all versions of verdictdb-core Show documentation
Platform-independent, interactive-speed data analytics system
/*
* Copyright 2018 University of Michigan
*
* 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 org.verdictdb.connection;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import org.apache.commons.lang3.tuple.ImmutablePair;
import org.apache.commons.lang3.tuple.Pair;
import org.verdictdb.exception.VerdictDBDbmsException;
public class CachedMetaDataProvider implements MetaDataProvider {
MetaDataProvider metaProvider;
// private String defaultSchema = null;
private List schemaCache = new ArrayList<>();
private HashMap> tablesCache = new HashMap<>();
private HashMap, List> partitionCache = new HashMap<>();
// Get column name and type
private HashMap, List>> columnsCache = new HashMap<>();
public CachedMetaDataProvider(MetaDataProvider metaProvider) {
this.metaProvider = metaProvider;
}
@Override
public List getSchemas() throws VerdictDBDbmsException {
if (!schemaCache.isEmpty()) {
return schemaCache;
}
schemaCache.addAll(metaProvider.getSchemas());
return schemaCache;
}
@Override
public List getTables(String schema) throws VerdictDBDbmsException {
if (tablesCache.containsKey(schema) && !tablesCache.get(schema).isEmpty()) {
return tablesCache.get(schema);
}
tablesCache.put(schema, metaProvider.getTables(schema));
return tablesCache.get(schema);
}
@Override
public List> getColumns(String schema, String table)
throws VerdictDBDbmsException {
Pair key = new ImmutablePair<>(schema, table);
if (columnsCache.containsKey(key) && !columnsCache.get(key).isEmpty()) {
return columnsCache.get(key);
}
columnsCache.put(key, metaProvider.getColumns(schema, table));
return columnsCache.get(key);
}
/**
* Only needed for the DBMS that supports partitioning.
*
* @param schema
* @param table
* @return
* @throws VerdictDBDbmsException
*/
@Override
public List getPartitionColumns(String schema, String table)
throws VerdictDBDbmsException {
// if (!syntax.doesSupportTablePartitioning()) {
// throw new VerdictDBDbmsException("Database does not support table partitioning");
// }
Pair key = new ImmutablePair<>(schema, table);
if (columnsCache.containsKey(key) && !partitionCache.isEmpty()) {
return partitionCache.get(key);
}
partitionCache.put(key, metaProvider.getPartitionColumns(schema, table));
return partitionCache.get(key);
}
public String getDefaultSchema() {
String schema = metaProvider.getDefaultSchema();
// if (defaultSchema == null) {
// defaultSchema = metaProvider.getDefaultSchema();
// }
return schema;
}
public void setDefaultSchema(String schema) {
metaProvider.setDefaultSchema(schema);
// defaultSchema = schema;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy