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

io.vertx.oracleclient.impl.OracleColumnDesc Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR2
Show newest version
/*
 * Copyright (c) 2011-2022 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */
package io.vertx.oracleclient.impl;

import io.netty.util.collection.IntObjectHashMap;
import io.netty.util.collection.IntObjectMap;
import io.vertx.sqlclient.desc.ColumnDescriptor;
import oracle.sql.TIMESTAMPTZ;

import java.sql.JDBCType;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

public class OracleColumnDesc implements ColumnDescriptor {

  private static final IntObjectMap TYPES_BY_VENDOR_TYPE_NUMBER;
  private static final Map TYPES_BY_CLASSNAME;

  static {
    TYPES_BY_VENDOR_TYPE_NUMBER = new IntObjectHashMap<>();
    for (JDBCType type : JDBCType.values()) {
      TYPES_BY_VENDOR_TYPE_NUMBER.put(type.getVendorTypeNumber(), type);
    }
    TYPES_BY_CLASSNAME = new HashMap<>();
    TYPES_BY_CLASSNAME.put(TIMESTAMPTZ.class.getName(), JDBCType.TIMESTAMP_WITH_TIMEZONE);
  }

  private final String name;
  private final String typeName;
  private final JDBCType type;

  public OracleColumnDesc(ResultSetMetaData md, int idx) throws SQLException {
    name = md.getColumnLabel(idx);
    typeName = md.getColumnTypeName(idx);
    type = find(md, idx);
  }

  private JDBCType find(ResultSetMetaData md, int idx) throws SQLException {
    JDBCType res;
    if ((res = TYPES_BY_VENDOR_TYPE_NUMBER.get(md.getColumnType(idx))) == null) {
      if ((res = TYPES_BY_CLASSNAME.get(md.getColumnClassName(idx))) == null) {
        res = JDBCType.OTHER;
      }
    }
    return res;
  }

  @Override
  public String name() {
    return name;
  }

  @Override
  public boolean isArray() {
    return type == JDBCType.ARRAY;
  }

  @Override
  public String typeName() {
    return typeName;
  }

  @Override
  public JDBCType jdbcType() {
    return type;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy