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

com.pivotal.gemfirexd.internal.vti.VTIMetaDataTemplate Maven / Gradle / Ivy

There is a newer version: 2.0-BETA
Show newest version
/*

   Derby - Class com.pivotal.gemfirexd.internal.vti.VTIMetaDataTemplate

   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to You 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.

 */

/*
 * Changes for GemFireXD distributed data platform (some marked by "GemStone changes")
 *
 * Portions Copyright (c) 2010-2015 Pivotal Software, Inc. 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. See accompanying
 * LICENSE file.
 */

package com.pivotal.gemfirexd.internal.vti;

import java.sql.SQLException;
import java.sql.ResultSetMetaData;

/**
	An abstract implementation of ResultSetMetaData (JDBC 1.2) that is useful
	when writing a VTI (virtual table interface).
	
	This class implements
	most of the methods of ResultSetMetaData, each one throwing a SQLException
	with the name of the method. A concrete subclass can then just implement
	the methods not implemented here and override any methods it needs
	to implement for correct functionality.
	

The methods not implemented here are

  • getColumnCount()
  • getColumnType()

For virtual tables the database engine only calls methods defined in the JDBC 1.2 definition of java.sql.ResultSetMetaData.
Classes that implement a JDBC 2.0 conformant java.sql.ResultSetMetaData can be used as the meta data for virtual tables.
Developers can use the VTIMetaDataTemplate20 instead of this class when developing in a Java 2 environment. */ public abstract class VTIMetaDataTemplate implements ResultSetMetaData { /** * Is the column automatically numbered, and thus read-only? * * @param column the first column is 1, the second is 2, ... * @return true if the column is automatically numbered * @exception SQLException if a database-access error occurs. */ public boolean isAutoIncrement(int column) throws SQLException { throw new SQLException("isAutoIncrement"); } /** * Does a column's case matter? * * @param column the first column is 1, the second is 2, ... * @return true if the column is case-sensitive * @exception SQLException if a database-access error occurs. */ public boolean isCaseSensitive(int column) throws SQLException { throw new SQLException("isCaseSensitive"); } /** * Can the column be used in a WHERE clause? * * @param column the first column is 1, the second is 2, ... * @return true if the column is searchable * @exception SQLException if a database-access error occurs. */ public boolean isSearchable(int column) throws SQLException{ throw new SQLException("isSearchable"); } /** * Is the column a cash value? * * @param column the first column is 1, the second is 2, ... * @return true if the column is a cash value * @exception SQLException if a database-access error occurs. */ public boolean isCurrency(int column) throws SQLException{ throw new SQLException("isCurrency"); } /** * Can you put a NULL in this column? * * @param column the first column is 1, the second is 2, ... * @return columnNoNulls, columnNullable or columnNullableUnknown * @exception SQLException if a database-access error occurs. */ public int isNullable(int column) throws SQLException{ throw new SQLException("isNullable"); } /** * Is the column a signed number? * * @param column the first column is 1, the second is 2, ... * @return true if the column is a signed number * @exception SQLException if a database-access error occurs. */ public boolean isSigned(int column) throws SQLException { throw new SQLException("isSigned"); } /** * What's the column's normal maximum width in chars? * * @param column the first column is 1, the second is 2, ... * @return the column's maximum width * @exception SQLException if a database-access error occurs. */ public int getColumnDisplaySize(int column) throws SQLException { throw new SQLException("getColumnDisplaySize"); } /** * What's the suggested column title for use in printouts and * displays? * * @param column the first column is 1, the second is 2, ... * @return the column's title * @exception SQLException if a database-access error occurs. */ public String getColumnLabel(int column) throws SQLException { throw new SQLException("getColumnLabel"); } /** * What's a column's name? * * @param column the first column is 1, the second is 2, ... * @return column name * @exception SQLException if a database-access error occurs. */ public String getColumnName(int column) throws SQLException { throw new SQLException("getColumnName"); } /** * What's a column's table's schema? * * @param column the first column is 1, the second is 2, ... * @return schema name or "" if not applicable * @exception SQLException if a database-access error occurs. */ public String getSchemaName(int column) throws SQLException { throw new SQLException("getSchemaName"); } /** * How many decimal digits are in the column? * * @param column the first column is 1, the second is 2, ... * @return the column's precision * @exception SQLException if a database-access error occurs. */ public int getPrecision(int column) throws SQLException { throw new SQLException("getPrecision"); } /** * What's a column's number of digits to the right of the decimal point? * * @param column the first column is 1, the second is 2, ... * @return the column's scale * @exception SQLException if a database-access error occurs. */ public int getScale(int column) throws SQLException { throw new SQLException("getScale"); } /** * What's a column's table name? * * @param column the first column is 1, the second is 2, ... * @return the column's table name or "" if not applicable * @exception SQLException if a database-access error occurs. */ public String getTableName(int column) throws SQLException { throw new SQLException("getTableName"); } /** * What's a column's table's catalog name? * * @param column the first column is 1, the second is 2, ... * @return the column's table's catalog name or "" if not applicable. * @exception SQLException if a database-access error occurs. */ public String getCatalogName(int column) throws SQLException { throw new SQLException("getCatalogName"); } /** * What's a column's data source specific type name? * * @param column the first column is 1, the second is 2, ... * @return the column's type name * @exception SQLException if a database-access error occurs. */ public String getColumnTypeName(int column) throws SQLException { throw new SQLException("getColumnTypeName"); } /** * Is a column definitely not writable? * * @param column the first column is 1, the second is 2, ... * @return true - vti's are read only * false - column is not read-only * @exception SQLException if a database-access error occurs. */ public boolean isReadOnly(int column) throws SQLException { return true; } /** * Is it possible for a write on the column to succeed? * * @param column the first column is 1, the second is 2, ... * @return true if column is possibly writable * @exception SQLException if a database-access error occurs. */ public boolean isWritable(int column) throws SQLException { return false; } /** * Will a write on the column definitely succeed? * * @param column the first column is 1, the second is 2, ... * @return true if column is definitely writable * @exception SQLException if a database-access error occurs. */ public boolean isDefinitelyWritable(int column) throws SQLException { return false; } /* ** JDBC 2.0 */ /** * Returns the fully-qualified name of the Java class whose instances * are manufactured if the method ResultSet.getObject * is called to retrieve a value from the column. JDBC 2.0. * * @exception SQLException if a database-access error occurs */ public String getColumnClassName(int column) throws SQLException { throw new SQLException("getColumnClassName"); } // GemStone changes BEGIN // add dummy methods so this compiles with JDK 1.6 compiler public boolean isWrapperFor(Class interfaces) throws SQLException { throw new AssertionError("not implemented"); } /** * Returns this if this class implements the interface * * @param interfaces a Class defining an interface * @return an object that implements the interface * @throws java.sql.SQLExption if no object if found that implements the * interface */ public T unwrap(java.lang.Class interfaces) throws SQLException{ throw new AssertionError("not implemented"); } // GemStone changes END }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy