org.verdictdb.commons.AttributeValueRetrievalHelper Maven / Gradle / Ivy
/*
* 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.commons;
import java.io.ByteArrayInputStream;
import java.io.InputStream;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.net.URL;
import java.sql.Array;
import java.sql.Blob;
import java.sql.Clob;
import java.sql.Date;
import java.sql.NClob;
import java.sql.Ref;
import java.sql.RowId;
import java.sql.SQLException;
import java.sql.SQLXML;
import java.sql.Time;
import java.sql.Timestamp;
import java.util.HashMap;
import java.util.Map;
import javax.sql.rowset.serial.SerialBlob;
import org.verdictdb.jdbc41.VerdictJdbcArray;
public abstract class AttributeValueRetrievalHelper {
private Map lazyLabel2IndexMap = null;
protected Integer getIndexOf(String label) {
if (lazyLabel2IndexMap == null) {
constructLabel2IndexMap();
}
return lazyLabel2IndexMap.get(label);
}
private void constructLabel2IndexMap() {
int columnCount = getColumnCount();
lazyLabel2IndexMap = new HashMap<>();
for (int i = 0; i < columnCount; i++) {
lazyLabel2IndexMap.put(getColumnName(i), i);
}
}
public abstract String getColumnName(int i);
public abstract int getColumnCount();
public abstract Object getValue(int index);
// Actual implementations provided by this class
public Boolean getBoolean(int index) throws SQLException {
Object value = getValue(index);
if (value == null) {
return false;
}
if (value instanceof Boolean) {
return (boolean) value;
}
if (value instanceof Integer
|| value instanceof Long
|| value instanceof Double
|| value instanceof Float) {
int v = Integer.valueOf(value.toString());
if (v == 1) {
return true;
} else if (v == 0) {
return false;
}
} else if (value instanceof String) {
String v = value.toString();
// PostgreSql return t/f
// Redshift return true/false
if (v.equals("1") || v.equals("t") || v.equals("true")) {
return true;
} else if (v.equals("0") || v.equals("f") || v.equals("false")) {
return false;
}
}
throw new SQLException("Not a valid value for Boolean type: " + value);
}
public Boolean getBoolean(String label) throws SQLException {
int index = getIndexOf(label);
return getBoolean(index);
}
public String getString(int index) {
Object value = getValue(index);
if (value == null) {
return null;
}
return String.valueOf(value);
}
public String getString(String label) {
int index = getIndexOf(label);
return getString(index);
}
public int getInt(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
if (value instanceof String) {
String v = value.toString();
if (v.equals("t") || v.equals("true")) {
return 1;
} else if (v.equals("f") || v.equals("false")) {
return 0;
}
}
else if (value instanceof BigInteger) {
return ((BigInteger) value).intValue();
}
return TypeCasting.toInteger(value);
}
public int getInt(String label) {
int index = getIndexOf(label);
return getInt(index);
}
public long getLong(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
if (value instanceof String) {
String v = value.toString();
if (v.equals("t") || v.equals("true")) {
return 1;
} else if (v.equals("f") || v.equals("false")) {
return 0;
}
}
else if (value instanceof BigInteger) {
return ((BigInteger) value).longValue();
}
return TypeCasting.toLong(value);
}
public long getLong(String label) {
int index = getIndexOf(label);
return getLong(index);
}
public double getDouble(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
return TypeCasting.toDouble(value);
}
public double getDouble(String label) {
int index = getIndexOf(label);
return getDouble(index);
}
public float getFloat(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
return TypeCasting.toFloat(value);
}
public float getFloat(String label) {
int index = getIndexOf(label);
return getFloat(index);
}
public Date getDate(int index) {
Object value = getValue(index);
if (value == null) {
return null;
}
if (value instanceof Date) {
return (Date) value;
} else if (value instanceof Timestamp) {
return new Date(((Timestamp) value).getTime());
} else if (value instanceof Time) {
return new Date(((Time) value).getTime());
} else {
return null;
// throw new VerdictDBTypeException("Could not obtain Date from: " + value);
}
}
public Date getDate(String label) {
int index = getIndexOf(label);
return getDate(index);
}
public byte getByte(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
if (value instanceof String) {
String v = value.toString();
if (v.equals("t") || v.equals("true")) {
return 1;
} else if (v.equals("f") || v.equals("false")) {
return 0;
}
}
return (byte) TypeCasting.toByte(value);
}
public byte getByte(String label) {
int index = getIndexOf(label);
return getByte(index);
}
public Timestamp getTimestamp(int index) {
Object value = getValue(index);
if (value == null) {
return null;
}
if (value instanceof Date) {
return new Timestamp(((Date) value).getTime());
} else if (value instanceof Time) {
return new Timestamp(((Time) value).getTime());
} else if (value instanceof Timestamp) {
return (Timestamp) value;
} else {
return null;
}
}
public Timestamp getTimestamp(String label) {
int index = getIndexOf(label);
return getTimestamp(index);
}
public short getShort(int index) {
Object value = getValue(index);
if (value == null) {
return 0;
}
if (value instanceof String) {
String v = value.toString();
if (v.equals("t") || v.equals("true")) {
return 1;
} else if (v.equals("f") || v.equals("false")) {
return 0;
}
}
return TypeCasting.toShort(value);
}
public short getShort(String label) {
int index = getIndexOf(label);
return getShort(index);
}
public BigDecimal getBigDecimal(int index, int scale) {
Object value = TypeCasting.toBigDecimal(getValue(index), scale);
return (BigDecimal) value;
}
public BigDecimal getBigDecimal(String label, int scale) {
int index = getIndexOf(label);
return getBigDecimal(index, scale);
}
public BigDecimal getBigDecimal(int index) {
Object value = TypeCasting.toBigDecimal(getValue(index));
return (BigDecimal) value;
}
public BigDecimal getBigDecimal(String label) {
int index = getIndexOf(label);
return getBigDecimal(index);
}
public byte[] getBytes(int index) {
Object value = getValue(index);
return (byte[]) value;
}
public byte[] getBytes(String label) {
int index = getIndexOf(label);
return getBytes(index);
}
public Time getTime(int index) {
Object value = getValue(index);
if (value == null) {
return null;
}
if (value instanceof Date) {
return new Time(((Date) value).getTime());
} else if (value instanceof Time) {
return (Time) value;
} else if (value instanceof Timestamp) {
return new Time(((Timestamp) value).getTime());
} else {
return null;
}
}
public Time getTime(String label) {
int index = getIndexOf(label);
return getTime(index);
}
public InputStream getAsciiStream(int index) {
Object value = getValue(index);
return (InputStream) value;
}
public InputStream getAsciiStream(String label) {
int index = getIndexOf(label);
return getAsciiStream(index);
}
public InputStream getUnicodeStream(int index) {
Object value = getValue(index);
return (InputStream) value;
}
public InputStream getUnicodeStream(String label) {
int index = getIndexOf(label);
return getUnicodeStream(index);
}
public InputStream getBinaryStream(int index) {
Object value = getValue(index);
if (value == null) {
byte[] a = {};
return new ByteArrayInputStream(a);
}
if (value instanceof byte[]) {
ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream((byte[]) value);
return byteArrayInputStream;
}
return (InputStream) value;
}
public InputStream getBinaryStream(String label) {
int index = getIndexOf(label);
return getBinaryStream(index);
}
public Ref getRef(int index) {
Object value = getValue(index);
return (Ref) value;
}
public Ref getRef(String label) {
int index = getIndexOf(label);
return getRef(index);
}
public Blob getBlob(int index) throws SQLException {
Object value = getValue(index);
if (value == null) {
return null;
}
if (value instanceof Blob) {
return (Blob) value;
}
return new SerialBlob((byte[]) value);
}
public Blob getBlob(String label) throws SQLException {
int index = getIndexOf(label);
return getBlob(index);
}
public Clob getClob(int index) {
Object value = getValue(index);
return (Clob) value;
}
public Clob getClob(String label) {
int index = getIndexOf(label);
return getClob(index);
}
public Array getArray(int index) {
Object value = getValue(index);
VerdictJdbcArray array = new VerdictJdbcArray((Object[]) value);
return array;
}
public Array getArray(String label) {
int index = getIndexOf(label);
return getArray(index);
}
public URL getURL(int index) {
Object value = getValue(index);
return (URL) value;
}
public URL getURL(String label) {
int index = getIndexOf(label);
return getURL(index);
}
public RowId getRowId(int index) {
Object value = getValue(index);
return (RowId) value;
}
public RowId getRowId(String label) {
int index = getIndexOf(label);
return getRowId(index);
}
public NClob getNClob(int index) {
Object value = getValue(index);
return (NClob) value;
}
public NClob getNClob(String label) {
int index = getIndexOf(label);
return getNClob(index);
}
public SQLXML getSQLXML(int index) {
Object value = getValue(index);
return (SQLXML) value;
}
public SQLXML getSQLXML(String label) {
int index = getIndexOf(label);
return getSQLXML(index);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy