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

org.verdictdb.connection.CachedDbmsConnection Maven / Gradle / Ivy

The newest version!
/*
 *    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;
import org.verdictdb.sqlsyntax.SqlSyntax;

/**
 * Offers the same functionality as DbmsConnection; however, returns cached metadata whenever
 * possible to speed up query processing.
 *
 * @author Yongjoo Park
 */
public class CachedDbmsConnection extends DbmsConnection implements MetaDataProvider {

  DbmsConnection originalConn;

  public DbmsConnection getOriginalConn() {
    return originalConn;
  }

  public CachedDbmsConnection(DbmsConnection conn) {
    //    super(conn);
    this.originalConn = conn;
  }

  @Override
  public DbmsQueryResult execute(String query) throws VerdictDBDbmsException {
    return originalConn.execute(query);
  }

  @Override
  public SqlSyntax getSyntax() {
    return originalConn.getSyntax();
  }

  @Override
  public void abort() {
    originalConn.abort();
  }

  @Override
  public void close() {
    originalConn.close();
  }

  public DbmsConnection getOriginalConnection() {
    return originalConn;
  }

  @Override
  public DbmsConnection copy() throws VerdictDBDbmsException {
    CachedDbmsConnection newConn = new CachedDbmsConnection(originalConn.copy());
    return newConn;
  }

  //  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 void clearCache() {
    schemaCache.clear();
    tablesCache.clear();
    partitionCache.clear();
    columnsCache.clear();
  }

  @Override
  public List getSchemas() throws VerdictDBDbmsException {
    if (!schemaCache.isEmpty()) {
      return schemaCache;
    }
    synchronized (this) {
      List schemas = new ArrayList<>();
      schemaCache.clear();
      schemaCache.addAll(originalConn.getSchemas());
      schemas.addAll(schemaCache);
      return schemas;
    }
  }

  @Override
  public List getTables(String schema) throws VerdictDBDbmsException {
    if (tablesCache.containsKey(schema) && !tablesCache.get(schema).isEmpty()) {
      return tablesCache.get(schema);
    }
    return getTablesWithoutCaching(schema);
  }
  
  public List getTablesWithoutCaching(String schema) 
      throws VerdictDBDbmsException {
    synchronized (this) {
      List tables = new ArrayList<>();
      tablesCache.put(schema, originalConn.getTables(schema));
      tables.addAll(tablesCache.get(schema));
      return tables;
    }
  }

  @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);
    }
    synchronized (this) {
      List> columns = new ArrayList<>();
      columnsCache.put(key, originalConn.getColumns(schema, table));
      columns.addAll(columnsCache.get(key));
      return columns;
    }
  }

  /**
   * 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);
    }
    synchronized (this) {
      List columns = new ArrayList<>();
      partitionCache.put(key, originalConn.getPartitionColumns(schema, table));
      columns.addAll(partitionCache.get(key));
      return columns;
    }
  }

  public String getDefaultSchema() {
    String schema = originalConn.getDefaultSchema();
    return schema;
  }

  public void setDefaultSchema(String schema) throws VerdictDBDbmsException {
    originalConn.setDefaultSchema(schema);
  }

  @Override
  public List getPrimaryKey(String schema, String table) throws VerdictDBDbmsException {
    return originalConn.getPrimaryKey(schema, table);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy