org.verdictdb.jdbc41.VerdictResultSetMetaData 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.jdbc41;
import org.verdictdb.connection.DataTypeConverter;
import org.verdictdb.coordinator.VerdictSingleResult;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List;
public class VerdictResultSetMetaData implements ResultSetMetaData {
private VerdictSingleResult queryResult;
List caseSensitiveColumnTypes = Arrays.asList("char", "string", "text");
List signedColumnTypes = Arrays.asList("double", "int", "real");
public VerdictResultSetMetaData(VerdictSingleResult queryResult) {
this.queryResult = queryResult;
}
@Override
public T unwrap(Class iface) throws SQLException {
throw new SQLException("Not supported function.");
}
@Override
public boolean isWrapperFor(Class> iface) throws SQLException {
throw new SQLException("Not supported function.");
}
@Override
public int getColumnCount() throws SQLException {
return queryResult.getColumnCount();
}
@Override
public boolean isAutoIncrement(int column) throws SQLException {
return queryResult.getMetaData().isAutoIncrement.get(column - 1);
// throw new SQLException("Not supported function.");
}
@Override
public boolean isCaseSensitive(int column) throws SQLException {
String typeName = DataTypeConverter.typeName(queryResult.getColumnType(column - 1));
for (String a : caseSensitiveColumnTypes) {
if (typeName.contains(a)) {
return true;
}
}
return false;
}
@Override
public boolean isSearchable(int column) throws SQLException {
return false;
}
@Override
public boolean isCurrency(int column) throws SQLException {
return queryResult.getMetaData().isCurrency.get(column - 1);
// throw new SQLException("Not supported function.");
}
@Override
public int isNullable(int column) throws SQLException {
return queryResult.getMetaData().isNullable.get(column - 1);
// return java.sql.ResultSetMetaData.columnNullableUnknown;
}
@Override
public boolean isSigned(int column) throws SQLException {
String typeName = DataTypeConverter.typeName(queryResult.getColumnType(column - 1));
for (String a : signedColumnTypes) {
if (typeName.contains((a))) {
return true;
}
}
return false;
}
@Override
public int getColumnDisplaySize(int column) throws SQLException {
return queryResult.getMetaData().columnDisplaySize.get(column - 1);
// return Math.max(getPrecision(column), queryResult.getColumnName(column-1).length());
}
@Override
public String getColumnLabel(int column) throws SQLException {
return queryResult.getColumnName(column - 1);
}
@Override
public String getColumnName(int column) throws SQLException {
return queryResult.getColumnName(column - 1);
}
@Override
public String getSchemaName(int column) throws SQLException {
throw new SQLException("Not supported function.");
}
@Override
public int getPrecision(int column) throws SQLException {
return queryResult.getMetaData().precision.get(column - 1);
/*
int coltype = queryResult.getColumnType(column-1);
if (coltype == BIGINT) {
return 19;
}
else if (coltype == INTEGER) {
return 10;
}
else if (coltype == SMALLINT) {
return 5;
}
else if (coltype == TINYINT) {
return 3;
}
else if (coltype == DOUBLE || coltype == NUMERIC) {
return 64;
}
else if (coltype == FLOAT) {
return 17;
}
else if (coltype == DATE) {
return 10;
}
else if (coltype == TIME) {
return 8;
}
else if (coltype == TIMESTAMP) {
return 26;
}
else {
return 0;
}
*/
}
@Override
public int getScale(int column) throws SQLException {
return queryResult.getMetaData().scale.get(column - 1);
/*
String typeName = DataTypeConverter.typeName(queryResult.getColumnType(column-1));
if (typeName.contains("double") || typeName.contains("float")) {
return 10;
}
return 0;
*/
}
@Override
public String getTableName(int column) throws SQLException {
throw new SQLException("Not supported function.");
}
@Override
public String getCatalogName(int column) throws SQLException {
throw new SQLException("Not supported function.");
}
@Override
public int getColumnType(int column) throws SQLException {
return queryResult.getColumnType(column - 1);
}
@Override
public String getColumnTypeName(int column) throws SQLException {
return DataTypeConverter.typeName(queryResult.getColumnType(column - 1));
}
@Override
public boolean isReadOnly(int column) throws SQLException {
return true;
}
@Override
public boolean isWritable(int column) throws SQLException {
return false;
}
@Override
public boolean isDefinitelyWritable(int column) throws SQLException {
return false;
}
@Override
public String getColumnClassName(int column) throws SQLException {
return queryResult.getMetaData().columnClassName.get(column - 1);
// return DataTypeConverter.typeName(queryResult.getColumnType(column-1));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy