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

org.relique.jdbc.csv.CsvResultSetMetaData Maven / Gradle / Ivy

/*
 *  CsvJdbc - a JDBC driver for CSV files
 *  Copyright (C) 2001  Jonathan Ackerman
 *  Copyright (C) 2008, 2011  Mario Frasca
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 */
package org.relique.jdbc.csv;

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

/**
 * This class implements the java.sql.ResultSetMetaData JDBC interface for the
 * CsvJdbc driver.
 */
public class CsvResultSetMetaData implements ResultSetMetaData
{

	/** Names of columns */
	private String[] columnNames;
	private String[] columnLabels;
	private String[] columnTypes;
	private int[] columnDisplaySizes;
	/** Name of table */
	private String tableName;

	/**
	 * Constructor for the CsvResultSetMetaData object
	 * 
	 * @param tableName
	 *            Name of table
	 * @param columnTypes
	 *            Names of columns in table
	 */
	CsvResultSetMetaData(String tableName, String[] columnNames,
			String[] columnLabels, String[] columnTypes,
			int[] columnDisplaySizes)
	{
		this.tableName = tableName;
		this.columnNames = columnNames;
		this.columnLabels = columnLabels;
		this.columnTypes = columnTypes;
		this.columnDisplaySizes = columnDisplaySizes;
	}

	@Override
	public String getColumnClassName(int column) throws SQLException
	{
		return columnTypes[column - 1];
	}

	@Override
	public int getColumnCount() throws SQLException
	{
		return columnTypes.length;
	}

	@Override
	public String getCatalogName(int column) throws SQLException
	{
		return "";
	}

	@Override
	public int getColumnDisplaySize(int column) throws SQLException
	{
		return columnDisplaySizes[column - 1];
	}

	@Override
	public boolean isAutoIncrement(int column) throws SQLException
	{
		return false;
	}

	@Override
	public boolean isCaseSensitive(int column) throws SQLException
	{
		// all columns are uppercase
		return false;
	}

	@Override
	public boolean isSearchable(int column) throws SQLException
	{
		// the implementation doesn't support the where clause
		return false;
	}

	@Override
	public boolean isCurrency(int column) throws SQLException
	{
		return false;
	}

	@Override
	public int isNullable(int column) throws SQLException
	{
		return ResultSetMetaData.columnNullableUnknown;
	}

	@Override
	public boolean isSigned(int column) throws SQLException
	{
		return false;
	}

	@Override
	public String getColumnLabel(int column) throws SQLException
	{
		// SQL column numbers start at 1
		return columnLabels[column - 1];
	}

	@Override
	public String getColumnName(int column) throws SQLException
	{
		// SQL column numbers start at 1
		return columnNames[column - 1];
	}

	@Override
	public String getSchemaName(int column) throws SQLException
	{
		return "";
	}

	@Override
	public int getPrecision(int column) throws SQLException
	{
		// All the fields are text, should this throw an SQLException?
		return 0;
	}

	@Override
	public int getScale(int column) throws SQLException
	{
		// All the fields are text, should this throw an SQLException?
		return 0;
	}

	@Override
	public String getTableName(int column) throws SQLException
	{
		return tableName;
	}

	private Map typeNameToTypeCode = new HashMap()
	{
		private static final long serialVersionUID = -8819579540085202365L;

		{
			put("String", Integer.valueOf(Types.VARCHAR));
			put("Boolean", Integer.valueOf(Types.BOOLEAN));
			put("Byte", Integer.valueOf(Types.TINYINT));
			put("Short", Integer.valueOf(Types.SMALLINT));
			put("Int", Integer.valueOf(Types.INTEGER));
			put("Integer", Integer.valueOf(Types.INTEGER));
			put("Long", Integer.valueOf(Types.BIGINT));
			put("Float", Integer.valueOf(Types.FLOAT));
			put("Double", Integer.valueOf(Types.DOUBLE));
			put("BigDecimal", Integer.valueOf(Types.DECIMAL));
			put("Date", Integer.valueOf(Types.DATE));
			put("Time", Integer.valueOf(Types.TIME));
			put("Timestamp", Integer.valueOf(Types.TIMESTAMP));
			put("Blob", Integer.valueOf(Types.BLOB));
			put("Clob", Integer.valueOf(Types.CLOB));
			put("expression", Integer.valueOf(Types.BLOB));
		}
	};

	@Override
	public int getColumnType(int column) throws SQLException
	{
		String columnTypeName = getColumnTypeName(column);
		Integer value = typeNameToTypeCode.get(columnTypeName);
		return value.intValue();
	}

	@Override
	public String getColumnTypeName(int column) throws SQLException
	{
		return columnTypes[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 boolean isWrapperFor(Class arg0) throws SQLException
	{
		// TODO Auto-generated method stub
		return false;
	}

	@Override
	public  T unwrap(Class arg0) throws SQLException
	{
		// TODO Auto-generated method stub
		return null;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy