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

software.amazon.jdbc.wrapper.DatabaseMetaDataWrapper Maven / Gradle / Ivy

/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * 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 software.amazon.jdbc.wrapper;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.RowIdLifetime;
import java.sql.SQLException;
import java.util.StringJoiner;
import org.checkerframework.checker.nullness.qual.NonNull;
import software.amazon.jdbc.ConnectionPluginManager;
import software.amazon.jdbc.util.DriverInfo;
import software.amazon.jdbc.util.WrapperUtils;

public class DatabaseMetaDataWrapper implements DatabaseMetaData {

  protected DatabaseMetaData databaseMetaData;
  protected ConnectionPluginManager pluginManager;

  public DatabaseMetaDataWrapper(
      @NonNull DatabaseMetaData databaseMetaData, @NonNull ConnectionPluginManager pluginManager) {
    this.databaseMetaData = databaseMetaData;
    this.pluginManager = pluginManager;
  }

  @Override
  public boolean allProceduresAreCallable() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.allProceduresAreCallable",
        () -> this.databaseMetaData.allProceduresAreCallable());
  }

  @Override
  public boolean allTablesAreSelectable() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.allTablesAreSelectable",
        () -> this.databaseMetaData.allTablesAreSelectable());
  }

  @Override
  public String getURL() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getURL",
        () -> this.databaseMetaData.getURL());
  }

  @Override
  public String getUserName() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getUserName",
        () -> this.databaseMetaData.getUserName());
  }

  @Override
  public boolean isReadOnly() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.isReadOnly",
        () -> this.databaseMetaData.isReadOnly());
  }

  @Override
  public boolean nullsAreSortedHigh() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.nullsAreSortedHigh",
        () -> this.databaseMetaData.nullsAreSortedHigh());
  }

  @Override
  public boolean nullsAreSortedLow() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.nullsAreSortedLow",
        () -> this.databaseMetaData.nullsAreSortedLow());
  }

  @Override
  public boolean nullsAreSortedAtStart() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.nullsAreSortedAtStart",
        () -> this.databaseMetaData.nullsAreSortedAtStart());
  }

  @Override
  public boolean nullsAreSortedAtEnd() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.nullsAreSortedAtEnd",
        () -> this.databaseMetaData.nullsAreSortedAtEnd());
  }

  @Override
  public String getDatabaseProductName() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDatabaseProductName",
        () -> this.databaseMetaData.getDatabaseProductName());
  }

  @Override
  public String getDatabaseProductVersion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDatabaseProductVersion",
        () -> this.databaseMetaData.getDatabaseProductVersion());
  }

  @Override
  public String getDriverName() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDriverName",
        () -> DriverInfo.DRIVER_NAME);
  }

  @Override
  public String getDriverVersion() throws SQLException {
    final StringJoiner joiner = new StringJoiner(" ");
    joiner
        .add(DriverInfo.DRIVER_NAME)
        .add(DriverInfo.DRIVER_VERSION)
        .add("( Revision:").add(DriverInfo.REVISION_VERSION).add(")");
    return joiner.toString();
  }

  @Override
  public int getDriverMajorVersion() {
    return DriverInfo.MAJOR_VERSION;
  }

  @Override
  public int getDriverMinorVersion() {
    return DriverInfo.MINOR_VERSION;
  }

  @Override
  public boolean usesLocalFiles() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.usesLocalFiles",
        () -> this.databaseMetaData.usesLocalFiles());
  }

  @Override
  public boolean usesLocalFilePerTable() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.usesLocalFilePerTable",
        () -> this.databaseMetaData.usesLocalFilePerTable());
  }

  @Override
  public boolean supportsMixedCaseIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMixedCaseIdentifiers",
        () -> this.databaseMetaData.supportsMixedCaseIdentifiers());
  }

  @Override
  public boolean storesUpperCaseIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesUpperCaseIdentifiers",
        () -> this.databaseMetaData.storesUpperCaseIdentifiers());
  }

  @Override
  public boolean storesLowerCaseIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesLowerCaseIdentifiers",
        () -> this.databaseMetaData.storesLowerCaseIdentifiers());
  }

  @Override
  public boolean storesMixedCaseIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesMixedCaseIdentifiers",
        () -> this.databaseMetaData.storesMixedCaseIdentifiers());
  }

  @Override
  public boolean supportsMixedCaseQuotedIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMixedCaseQuotedIdentifiers",
        () -> this.databaseMetaData.supportsMixedCaseQuotedIdentifiers());
  }

  @Override
  public boolean storesUpperCaseQuotedIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesUpperCaseQuotedIdentifiers",
        () -> this.databaseMetaData.storesUpperCaseQuotedIdentifiers());
  }

  @Override
  public boolean storesLowerCaseQuotedIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesLowerCaseQuotedIdentifiers",
        () -> this.databaseMetaData.storesLowerCaseQuotedIdentifiers());
  }

  @Override
  public boolean storesMixedCaseQuotedIdentifiers() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.storesMixedCaseQuotedIdentifiers",
        () -> this.databaseMetaData.storesMixedCaseQuotedIdentifiers());
  }

  @Override
  public String getIdentifierQuoteString() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getIdentifierQuoteString",
        () -> this.databaseMetaData.getIdentifierQuoteString());
  }

  @Override
  public String getSQLKeywords() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSQLKeywords",
        () -> this.databaseMetaData.getSQLKeywords());
  }

  @Override
  public String getNumericFunctions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getNumericFunctions",
        () -> this.databaseMetaData.getNumericFunctions());
  }

  @Override
  public String getStringFunctions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getStringFunctions",
        () -> this.databaseMetaData.getStringFunctions());
  }

  @Override
  public String getSystemFunctions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSystemFunctions",
        () -> this.databaseMetaData.getSystemFunctions());
  }

  @Override
  public String getTimeDateFunctions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getTimeDateFunctions",
        () -> this.databaseMetaData.getTimeDateFunctions());
  }

  @Override
  public String getSearchStringEscape() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSearchStringEscape",
        () -> this.databaseMetaData.getSearchStringEscape());
  }

  @Override
  public String getExtraNameCharacters() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getExtraNameCharacters",
        () -> this.databaseMetaData.getExtraNameCharacters());
  }

  @Override
  public boolean supportsAlterTableWithAddColumn() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsAlterTableWithAddColumn",
        () -> this.databaseMetaData.supportsAlterTableWithAddColumn());
  }

  @Override
  public boolean supportsAlterTableWithDropColumn() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsAlterTableWithDropColumn",
        () -> this.databaseMetaData.supportsAlterTableWithDropColumn());
  }

  @Override
  public boolean supportsColumnAliasing() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsColumnAliasing",
        () -> this.databaseMetaData.supportsColumnAliasing());
  }

  @Override
  public boolean nullPlusNonNullIsNull() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.nullPlusNonNullIsNull",
        () -> this.databaseMetaData.nullPlusNonNullIsNull());
  }

  @Override
  public boolean supportsConvert() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsConvert",
        () -> this.databaseMetaData.supportsConvert());
  }

  @Override
  public boolean supportsConvert(int fromType, int toType) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsConvert",
        () -> this.databaseMetaData.supportsConvert(fromType, toType),
        fromType,
        toType);
  }

  @Override
  public boolean supportsTableCorrelationNames() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsTableCorrelationNames",
        () -> this.databaseMetaData.supportsTableCorrelationNames());
  }

  @Override
  public boolean supportsDifferentTableCorrelationNames() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsDifferentTableCorrelationNames",
        () -> this.databaseMetaData.supportsDifferentTableCorrelationNames());
  }

  @Override
  public boolean supportsExpressionsInOrderBy() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsExpressionsInOrderBy",
        () -> this.databaseMetaData.supportsExpressionsInOrderBy());
  }

  @Override
  public boolean supportsOrderByUnrelated() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOrderByUnrelated",
        () -> this.databaseMetaData.supportsOrderByUnrelated());
  }

  @Override
  public boolean supportsGroupBy() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsGroupBy",
        () -> this.databaseMetaData.supportsGroupBy());
  }

  @Override
  public boolean supportsGroupByUnrelated() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsGroupByUnrelated",
        () -> this.databaseMetaData.supportsGroupByUnrelated());
  }

  @Override
  public boolean supportsGroupByBeyondSelect() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsGroupByBeyondSelect",
        () -> this.databaseMetaData.supportsGroupByBeyondSelect());
  }

  @Override
  public boolean supportsLikeEscapeClause() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsLikeEscapeClause",
        () -> this.databaseMetaData.supportsLikeEscapeClause());
  }

  @Override
  public boolean supportsMultipleResultSets() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMultipleResultSets",
        () -> this.databaseMetaData.supportsMultipleResultSets());
  }

  @Override
  public boolean supportsMultipleTransactions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMultipleTransactions",
        () -> this.databaseMetaData.supportsMultipleTransactions());
  }

  @Override
  public boolean supportsNonNullableColumns() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsNonNullableColumns",
        () -> this.databaseMetaData.supportsNonNullableColumns());
  }

  @Override
  public boolean supportsMinimumSQLGrammar() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMinimumSQLGrammar",
        () -> this.databaseMetaData.supportsMinimumSQLGrammar());
  }

  @Override
  public boolean supportsCoreSQLGrammar() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCoreSQLGrammar",
        () -> this.databaseMetaData.supportsCoreSQLGrammar());
  }

  @Override
  public boolean supportsExtendedSQLGrammar() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsExtendedSQLGrammar",
        () -> this.databaseMetaData.supportsExtendedSQLGrammar());
  }

  @Override
  public boolean supportsANSI92EntryLevelSQL() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsANSI92EntryLevelSQL",
        () -> this.databaseMetaData.supportsANSI92EntryLevelSQL());
  }

  @Override
  public boolean supportsANSI92IntermediateSQL() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsANSI92IntermediateSQL",
        () -> this.databaseMetaData.supportsANSI92IntermediateSQL());
  }

  @Override
  public boolean supportsANSI92FullSQL() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsANSI92FullSQL",
        () -> this.databaseMetaData.supportsANSI92FullSQL());
  }

  @Override
  public boolean supportsIntegrityEnhancementFacility() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsIntegrityEnhancementFacility",
        () -> this.databaseMetaData.supportsIntegrityEnhancementFacility());
  }

  @Override
  public boolean supportsOuterJoins() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOuterJoins",
        () -> this.databaseMetaData.supportsOuterJoins());
  }

  @Override
  public boolean supportsFullOuterJoins() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsFullOuterJoins",
        () -> this.databaseMetaData.supportsFullOuterJoins());
  }

  @Override
  public boolean supportsLimitedOuterJoins() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsLimitedOuterJoins",
        () -> this.databaseMetaData.supportsLimitedOuterJoins());
  }

  @Override
  public String getSchemaTerm() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSchemaTerm",
        () -> this.databaseMetaData.getSchemaTerm());
  }

  @Override
  public String getProcedureTerm() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getProcedureTerm",
        () -> this.databaseMetaData.getProcedureTerm());
  }

  @Override
  public String getCatalogTerm() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getCatalogTerm",
        () -> this.databaseMetaData.getCatalogTerm());
  }

  @Override
  public boolean isCatalogAtStart() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.isCatalogAtStart",
        () -> this.databaseMetaData.isCatalogAtStart());
  }

  @Override
  public String getCatalogSeparator() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        String.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getCatalogSeparator",
        () -> this.databaseMetaData.getCatalogSeparator());
  }

  @Override
  public boolean supportsSchemasInDataManipulation() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSchemasInDataManipulation",
        () -> this.databaseMetaData.supportsSchemasInDataManipulation());
  }

  @Override
  public boolean supportsSchemasInProcedureCalls() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSchemasInProcedureCalls",
        () -> this.databaseMetaData.supportsSchemasInProcedureCalls());
  }

  @Override
  public boolean supportsSchemasInTableDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSchemasInTableDefinitions",
        () -> this.databaseMetaData.supportsSchemasInTableDefinitions());
  }

  @Override
  public boolean supportsSchemasInIndexDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSchemasInIndexDefinitions",
        () -> this.databaseMetaData.supportsSchemasInIndexDefinitions());
  }

  @Override
  public boolean supportsSchemasInPrivilegeDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSchemasInPrivilegeDefinitions",
        () -> this.databaseMetaData.supportsSchemasInPrivilegeDefinitions());
  }

  @Override
  public boolean supportsCatalogsInDataManipulation() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCatalogsInDataManipulation",
        () -> this.databaseMetaData.supportsCatalogsInDataManipulation());
  }

  @Override
  public boolean supportsCatalogsInProcedureCalls() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCatalogsInProcedureCalls",
        () -> this.databaseMetaData.supportsCatalogsInProcedureCalls());
  }

  @Override
  public boolean supportsCatalogsInTableDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCatalogsInTableDefinitions",
        () -> this.databaseMetaData.supportsCatalogsInTableDefinitions());
  }

  @Override
  public boolean supportsCatalogsInIndexDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCatalogsInIndexDefinitions",
        () -> this.databaseMetaData.supportsCatalogsInIndexDefinitions());
  }

  @Override
  public boolean supportsCatalogsInPrivilegeDefinitions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCatalogsInPrivilegeDefinitions",
        () -> this.databaseMetaData.supportsCatalogsInPrivilegeDefinitions());
  }

  @Override
  public boolean supportsPositionedDelete() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsPositionedDelete",
        () -> this.databaseMetaData.supportsPositionedDelete());
  }

  @Override
  public boolean supportsPositionedUpdate() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsPositionedUpdate",
        () -> this.databaseMetaData.supportsPositionedUpdate());
  }

  @Override
  public boolean supportsSelectForUpdate() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSelectForUpdate",
        () -> this.databaseMetaData.supportsSelectForUpdate());
  }

  @Override
  public boolean supportsStoredProcedures() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsStoredProcedures",
        () -> this.databaseMetaData.supportsStoredProcedures());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsSubqueriesInComparisons() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSubqueriesInComparisons",
        () -> this.databaseMetaData.supportsSubqueriesInComparisons());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsSubqueriesInExists() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSubqueriesInExists",
        () -> this.databaseMetaData.supportsSubqueriesInExists());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsSubqueriesInIns() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSubqueriesInIns",
        () -> this.databaseMetaData.supportsSubqueriesInIns());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsSubqueriesInQuantifieds() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSubqueriesInQuantifieds",
        () -> this.databaseMetaData.supportsSubqueriesInQuantifieds());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsCorrelatedSubqueries() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsCorrelatedSubqueries",
        () -> this.databaseMetaData.supportsCorrelatedSubqueries());
  }

  @Override
  public boolean supportsUnion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsUnion",
        () -> this.databaseMetaData.supportsUnion());
  }

  @Override
  public boolean supportsUnionAll() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsUnionAll",
        () -> this.databaseMetaData.supportsUnionAll());
  }

  @Override
  public boolean supportsOpenCursorsAcrossCommit() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOpenCursorsAcrossCommit",
        () -> this.databaseMetaData.supportsOpenCursorsAcrossCommit());
  }

  @Override
  public boolean supportsOpenCursorsAcrossRollback() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOpenCursorsAcrossRollback",
        () -> this.databaseMetaData.supportsOpenCursorsAcrossRollback());
  }

  @Override
  public boolean supportsOpenStatementsAcrossCommit() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOpenStatementsAcrossCommit",
        () -> this.databaseMetaData.supportsOpenStatementsAcrossCommit());
  }

  @Override
  public boolean supportsOpenStatementsAcrossRollback() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsOpenStatementsAcrossRollback",
        () -> this.databaseMetaData.supportsOpenStatementsAcrossRollback());
  }

  @Override
  public int getMaxBinaryLiteralLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxBinaryLiteralLength",
        () -> this.databaseMetaData.getMaxBinaryLiteralLength());
  }

  @Override
  public int getMaxCharLiteralLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxCharLiteralLength",
        () -> this.databaseMetaData.getMaxCharLiteralLength());
  }

  @Override
  public int getMaxColumnNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnNameLength",
        () -> this.databaseMetaData.getMaxColumnNameLength());
  }

  @Override
  public int getMaxColumnsInGroupBy() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnsInGroupBy",
        () -> this.databaseMetaData.getMaxColumnsInGroupBy());
  }

  @Override
  public int getMaxColumnsInIndex() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnsInIndex",
        () -> this.databaseMetaData.getMaxColumnsInIndex());
  }

  @Override
  public int getMaxColumnsInOrderBy() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnsInOrderBy",
        () -> this.databaseMetaData.getMaxColumnsInOrderBy());
  }

  @Override
  public int getMaxColumnsInSelect() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnsInSelect",
        () -> this.databaseMetaData.getMaxColumnsInSelect());
  }

  @Override
  public int getMaxColumnsInTable() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxColumnsInTable",
        () -> this.databaseMetaData.getMaxColumnsInTable());
  }

  @Override
  public int getMaxConnections() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxConnections",
        () -> this.databaseMetaData.getMaxConnections());
  }

  @Override
  public int getMaxCursorNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxCursorNameLength",
        () -> this.databaseMetaData.getMaxCursorNameLength());
  }

  @Override
  public int getMaxIndexLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxIndexLength",
        () -> this.databaseMetaData.getMaxIndexLength());
  }

  @Override
  public int getMaxSchemaNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxSchemaNameLength",
        () -> this.databaseMetaData.getMaxSchemaNameLength());
  }

  @Override
  public int getMaxProcedureNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxProcedureNameLength",
        () -> this.databaseMetaData.getMaxProcedureNameLength());
  }

  @Override
  public int getMaxCatalogNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxCatalogNameLength",
        () -> this.databaseMetaData.getMaxCatalogNameLength());
  }

  @Override
  public int getMaxRowSize() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxRowSize",
        () -> this.databaseMetaData.getMaxRowSize());
  }

  @Override
  public boolean doesMaxRowSizeIncludeBlobs() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.doesMaxRowSizeIncludeBlobs",
        () -> this.databaseMetaData.doesMaxRowSizeIncludeBlobs());
  }

  @Override
  public int getMaxStatementLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxStatementLength",
        () -> this.databaseMetaData.getMaxStatementLength());
  }

  @Override
  public int getMaxStatements() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxStatements",
        () -> this.databaseMetaData.getMaxStatements());
  }

  @Override
  public int getMaxTableNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxTableNameLength",
        () -> this.databaseMetaData.getMaxTableNameLength());
  }

  @Override
  public int getMaxTablesInSelect() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxTablesInSelect",
        () -> this.databaseMetaData.getMaxTablesInSelect());
  }

  @Override
  public int getMaxUserNameLength() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxUserNameLength",
        () -> this.databaseMetaData.getMaxUserNameLength());
  }

  @Override
  public int getDefaultTransactionIsolation() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDefaultTransactionIsolation",
        () -> this.databaseMetaData.getDefaultTransactionIsolation());
  }

  @Override
  public boolean supportsTransactions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsTransactions",
        () -> this.databaseMetaData.supportsTransactions());
  }

  @Override
  public boolean supportsTransactionIsolationLevel(int level) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsTransactionIsolationLevel",
        () -> this.databaseMetaData.supportsTransactionIsolationLevel(level),
        level);
  }

  @Override
  public boolean supportsDataDefinitionAndDataManipulationTransactions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsDataDefinitionAndDataManipulationTransactions",
        () -> this.databaseMetaData.supportsDataDefinitionAndDataManipulationTransactions());
  }

  @Override
  public boolean supportsDataManipulationTransactionsOnly() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsDataManipulationTransactionsOnly",
        () -> this.databaseMetaData.supportsDataManipulationTransactionsOnly());
  }

  @Override
  public boolean dataDefinitionCausesTransactionCommit() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.dataDefinitionCausesTransactionCommit",
        () -> this.databaseMetaData.dataDefinitionCausesTransactionCommit());
  }

  @Override
  public boolean dataDefinitionIgnoredInTransactions() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.dataDefinitionIgnoredInTransactions",
        () -> this.databaseMetaData.dataDefinitionIgnoredInTransactions());
  }

  @Override
  public ResultSet getProcedures(String catalog, String schemaPattern, String procedureNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getProcedures",
        () -> this.databaseMetaData.getProcedures(catalog, schemaPattern, procedureNamePattern),
        catalog,
        schemaPattern,
        procedureNamePattern);
  }

  @Override
  public ResultSet getProcedureColumns(
      String catalog, String schemaPattern, String procedureNamePattern, String columnNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getProcedureColumns",
        () ->
            this.databaseMetaData.getProcedureColumns(
                catalog, schemaPattern, procedureNamePattern, columnNamePattern),
        catalog,
        schemaPattern,
        procedureNamePattern,
        columnNamePattern);
  }

  @Override
  public ResultSet getTables(
      String catalog, String schemaPattern, String tableNamePattern, String[] types)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getTables",
        () -> this.databaseMetaData.getTables(catalog, schemaPattern, tableNamePattern, types),
        catalog,
        schemaPattern,
        tableNamePattern,
        types);
  }

  @Override
  public ResultSet getSchemas() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSchemas",
        () -> this.databaseMetaData.getSchemas());
  }

  @Override
  public ResultSet getSchemas(String catalog, String schemaPattern) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSchemas",
        () -> this.databaseMetaData.getSchemas(catalog, schemaPattern),
        catalog,
        schemaPattern);
  }

  @Override
  public ResultSet getCatalogs() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getCatalogs",
        () -> this.databaseMetaData.getCatalogs());
  }

  @Override
  public ResultSet getTableTypes() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getTableTypes",
        () -> this.databaseMetaData.getTableTypes());
  }

  @Override
  public ResultSet getColumns(
      String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getColumns",
        () ->
            this.databaseMetaData.getColumns(
                catalog, schemaPattern, tableNamePattern, columnNamePattern),
        catalog,
        schemaPattern,
        tableNamePattern,
        columnNamePattern);
  }

  @Override
  public ResultSet getColumnPrivileges(
      String catalog, String schema, String table, String columnNamePattern) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getColumnPrivileges",
        () -> this.databaseMetaData.getColumnPrivileges(catalog, schema, table, columnNamePattern),
        catalog,
        schema,
        table,
        columnNamePattern);
  }

  @Override
  public ResultSet getTablePrivileges(String catalog, String schemaPattern, String tableNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getTablePrivileges",
        () -> this.databaseMetaData.getTablePrivileges(catalog, schemaPattern, tableNamePattern),
        catalog,
        schemaPattern,
        tableNamePattern);
  }

  @Override
  public ResultSet getBestRowIdentifier(
      String catalog, String schema, String table, int scope, boolean nullable)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getBestRowIdentifier",
        () -> this.databaseMetaData.getBestRowIdentifier(catalog, schema, table, scope, nullable),
        catalog,
        schema,
        table,
        scope,
        nullable);
  }

  @Override
  public ResultSet getVersionColumns(String catalog, String schema, String table)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getVersionColumns",
        () -> this.databaseMetaData.getVersionColumns(catalog, schema, table),
        catalog,
        schema,
        table);
  }

  @Override
  public ResultSet getPrimaryKeys(String catalog, String schema, String table) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getPrimaryKeys",
        () -> this.databaseMetaData.getPrimaryKeys(catalog, schema, table),
        catalog,
        schema,
        table);
  }

  @Override
  public ResultSet getImportedKeys(String catalog, String schema, String table)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getImportedKeys",
        () -> this.databaseMetaData.getImportedKeys(catalog, schema, table),
        catalog,
        schema,
        table);
  }

  @Override
  public ResultSet getExportedKeys(String catalog, String schema, String table)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getExportedKeys",
        () -> this.databaseMetaData.getExportedKeys(catalog, schema, table),
        catalog,
        schema,
        table);
  }

  @Override
  public ResultSet getCrossReference(
      String parentCatalog,
      String parentSchema,
      String parentTable,
      String foreignCatalog,
      String foreignSchema,
      String foreignTable)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getCrossReference",
        () ->
            this.databaseMetaData.getCrossReference(
                parentCatalog,
                parentSchema,
                parentTable,
                foreignCatalog,
                foreignSchema,
                foreignTable),
        parentCatalog,
        parentSchema,
        parentTable,
        foreignCatalog,
        foreignSchema,
        foreignTable);
  }

  @Override
  public ResultSet getTypeInfo() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getTypeInfo",
        () -> this.databaseMetaData.getTypeInfo());
  }

  @Override
  public ResultSet getIndexInfo(
      String catalog, String schema, String table, boolean unique, boolean approximate)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getIndexInfo",
        () -> this.databaseMetaData.getIndexInfo(catalog, schema, table, unique, approximate),
        catalog,
        schema,
        table,
        unique,
        approximate);
  }

  @Override
  public boolean supportsResultSetType(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsResultSetType",
        () -> this.databaseMetaData.supportsResultSetType(type),
        type);
  }

  @Override
  public boolean supportsResultSetConcurrency(int type, int concurrency) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsResultSetConcurrency",
        () -> this.databaseMetaData.supportsResultSetConcurrency(type, concurrency),
        type,
        concurrency);
  }

  @Override
  public boolean ownUpdatesAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.ownUpdatesAreVisible",
        () -> this.databaseMetaData.ownUpdatesAreVisible(type),
        type);
  }

  @Override
  public boolean ownDeletesAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.ownDeletesAreVisible",
        () -> this.databaseMetaData.ownDeletesAreVisible(type),
        type);
  }

  @Override
  public boolean ownInsertsAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.ownInsertsAreVisible",
        () -> this.databaseMetaData.ownInsertsAreVisible(type),
        type);
  }

  @Override
  public boolean othersUpdatesAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.othersUpdatesAreVisible",
        () -> this.databaseMetaData.othersUpdatesAreVisible(type),
        type);
  }

  @Override
  public boolean othersDeletesAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.othersDeletesAreVisible",
        () -> this.databaseMetaData.othersDeletesAreVisible(type),
        type);
  }

  @Override
  public boolean othersInsertsAreVisible(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.othersInsertsAreVisible",
        () -> this.databaseMetaData.othersInsertsAreVisible(type),
        type);
  }

  @Override
  public boolean updatesAreDetected(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.updatesAreDetected",
        () -> this.databaseMetaData.updatesAreDetected(type),
        type);
  }

  @Override
  public boolean deletesAreDetected(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.deletesAreDetected",
        () -> this.databaseMetaData.deletesAreDetected(type),
        type);
  }

  @Override
  public boolean insertsAreDetected(int type) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.insertsAreDetected",
        () -> this.databaseMetaData.insertsAreDetected(type),
        type);
  }

  @Override
  public boolean supportsBatchUpdates() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsBatchUpdates",
        () -> this.databaseMetaData.supportsBatchUpdates());
  }

  @Override
  public ResultSet getUDTs(
      String catalog, String schemaPattern, String typeNamePattern, int[] types)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getUDTs",
        () -> this.databaseMetaData.getUDTs(catalog, schemaPattern, typeNamePattern, types),
        catalog,
        schemaPattern,
        typeNamePattern,
        types);
  }

  @Override
  public Connection getConnection() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        Connection.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getConnection",
        () -> this.pluginManager.getConnectionWrapper());
  }

  @SuppressWarnings("SpellCheckingInspection")
  @Override
  public boolean supportsSavepoints() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsSavepoints",
        () -> this.databaseMetaData.supportsSavepoints());
  }

  @Override
  public boolean supportsNamedParameters() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsNamedParameters",
        () -> this.databaseMetaData.supportsNamedParameters());
  }

  @Override
  public boolean supportsMultipleOpenResults() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsMultipleOpenResults",
        () -> this.databaseMetaData.supportsMultipleOpenResults());
  }

  @Override
  public boolean supportsGetGeneratedKeys() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsGetGeneratedKeys",
        () -> this.databaseMetaData.supportsGetGeneratedKeys());
  }

  @Override
  public ResultSet getSuperTypes(String catalog, String schemaPattern, String typeNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSuperTypes",
        () -> this.databaseMetaData.getSuperTypes(catalog, schemaPattern, typeNamePattern),
        catalog,
        schemaPattern,
        typeNamePattern);
  }

  @Override
  public ResultSet getSuperTables(String catalog, String schemaPattern, String tableNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSuperTables",
        () -> this.databaseMetaData.getSuperTables(catalog, schemaPattern, tableNamePattern),
        catalog,
        schemaPattern,
        tableNamePattern);
  }

  @Override
  public ResultSet getAttributes(
      String catalog, String schemaPattern, String typeNamePattern, String attributeNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getAttributes",
        () ->
            this.databaseMetaData.getAttributes(
                catalog, schemaPattern, typeNamePattern, attributeNamePattern),
        catalog,
        schemaPattern,
        typeNamePattern,
        attributeNamePattern);
  }

  @Override
  public boolean supportsResultSetHoldability(int holdability) throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsResultSetHoldability",
        () -> this.databaseMetaData.supportsResultSetHoldability(holdability),
        holdability);
  }

  @Override
  public int getResultSetHoldability() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getResultSetHoldability",
        () -> this.databaseMetaData.getResultSetHoldability());
  }

  @Override
  public int getDatabaseMajorVersion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDatabaseMajorVersion",
        () -> this.databaseMetaData.getDatabaseMajorVersion());
  }

  @Override
  public int getDatabaseMinorVersion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getDatabaseMinorVersion",
        () -> this.databaseMetaData.getDatabaseMinorVersion());
  }

  @Override
  public int getJDBCMajorVersion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getJDBCMajorVersion",
        () -> this.databaseMetaData.getJDBCMajorVersion());
  }

  @Override
  public int getJDBCMinorVersion() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getJDBCMinorVersion",
        () -> this.databaseMetaData.getJDBCMinorVersion());
  }

  @SuppressWarnings("MagicConstant")
  @Override
  public int getSQLStateType() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        int.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getSQLStateType",
        () -> this.databaseMetaData.getSQLStateType());
  }

  @Override
  public boolean locatorsUpdateCopy() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.locatorsUpdateCopy",
        () -> this.databaseMetaData.locatorsUpdateCopy());
  }

  @Override
  public boolean supportsStatementPooling() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsStatementPooling",
        () -> this.databaseMetaData.supportsStatementPooling());
  }

  @Override
  public RowIdLifetime getRowIdLifetime() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        RowIdLifetime.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getRowIdLifetime",
        () -> this.databaseMetaData.getRowIdLifetime());
  }

  @Override
  public boolean supportsStoredFunctionsUsingCallSyntax() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsStoredFunctionsUsingCallSyntax",
        () -> this.databaseMetaData.supportsStoredFunctionsUsingCallSyntax());
  }

  @Override
  public boolean autoCommitFailureClosesAllResultSets() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.autoCommitFailureClosesAllResultSets",
        () -> this.databaseMetaData.autoCommitFailureClosesAllResultSets());
  }

  @Override
  public ResultSet getClientInfoProperties() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getClientInfoProperties",
        () -> this.databaseMetaData.getClientInfoProperties());
  }

  @Override
  public ResultSet getFunctions(String catalog, String schemaPattern, String functionNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getFunctions",
        () -> this.databaseMetaData.getFunctions(catalog, schemaPattern, functionNamePattern),
        catalog,
        schemaPattern,
        functionNamePattern);
  }

  @Override
  public ResultSet getFunctionColumns(
      String catalog, String schemaPattern, String functionNamePattern, String columnNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getFunctionColumns",
        () ->
            this.databaseMetaData.getFunctionColumns(
                catalog, schemaPattern, functionNamePattern, columnNamePattern),
        catalog,
        schemaPattern,
        functionNamePattern,
        columnNamePattern);
  }

  @Override
  public ResultSet getPseudoColumns(
      String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern)
      throws SQLException {
    return WrapperUtils.executeWithPlugins(
        ResultSet.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getPseudoColumns",
        () ->
            this.databaseMetaData.getPseudoColumns(
                catalog, schemaPattern, tableNamePattern, columnNamePattern),
        catalog,
        schemaPattern,
        tableNamePattern,
        columnNamePattern);
  }

  @Override
  public boolean generatedKeyAlwaysReturned() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.generatedKeyAlwaysReturned",
        () -> this.databaseMetaData.generatedKeyAlwaysReturned());
  }

  @Override
  public long getMaxLogicalLobSize() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        long.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.getMaxLogicalLobSize",
        () -> this.databaseMetaData.getMaxLogicalLobSize());
  }

  @Override
  public boolean supportsRefCursors() throws SQLException {
    return WrapperUtils.executeWithPlugins(
        boolean.class,
        SQLException.class,
        this.pluginManager,
        this.databaseMetaData,
        "DatabaseMetaData.supportsRefCursors",
        () -> this.databaseMetaData.supportsRefCursors());
  }

  @Override
  public  T unwrap(Class iface) throws SQLException {
    return this.databaseMetaData.unwrap(iface);
  }

  @Override
  public boolean isWrapperFor(Class iface) throws SQLException {
    return this.databaseMetaData.isWrapperFor(iface);
  }

  @Override
  public String toString() {
    return super.toString() + " - " + this.databaseMetaData;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy