/* * * SchemaCrawler * http://sourceforge.net/projects/schemacrawler * Copyright (c) 2000-2011, Sualeh Fatehi. * * 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., 59 Temple Place, Suite 330, * Boston, MA 02111-1307, USA. * */ package schemacrawler.schema; /** * Represents a column type. Provides the java.sql.Types type, the * java.sql.Types type name, and the database specific data type name. * * @author Sualeh Fatehi */ public interface ColumnDataType extends DatabaseObject { /** * Gets the base type of the data type. * * @return Base type */ ColumnDataType getBaseType(); /** * Gets the parameters needed when using this data type. * * @return Parameters needed when using this data type */ String getCreateParameters(); /** * Gets the database specific data type name. * * @return Database specific data type name */ String getDatabaseSpecificTypeName(); /** * Gets the literal prefix. * * @return Literal prefix */ String getLiteralPrefix(); /** * Gets the literal suffix. * * @return Literal suffix */ String getLiteralSuffix(); /** * Gets the local data type name. * * @return Local data type name */ String getLocalTypeName(); /** * Gets the maximum scale. * * @return Maximum scale */ int getMaximumScale(); /** * Gets the minimum scale. * * @return Minimum scale */ int getMinimumScale(); /** * Gets the precision of the radix. * * @return Precision of the radix */ int getNumPrecisionRadix(); /** * Gets the precision. * * @return Precision */ long getPrecision(); /** * Gets the search method. * * @return Search method */ SearchableType getSearchable(); /** * Gets the java.sql.Types type. * * @return java.sql.Types type */ int getType(); /** * Gets the Java class name for the type. * * @return The Java class name for the type */ String getTypeClassName(); /** * Gets the java.sql.Types type name. * * @return java.sql.Types type name */ String getTypeName(); /** * Whether the data type is auto-incrementable. * * @return Whether the data type is auto-incrementable */ boolean isAutoIncrementable(); /** * Whether the data type is case-sensitive. * * @return Whether the data type is case-sensitive */ boolean isCaseSensitive(); /** * Whether the data type has a fixed precision scale. * * @return Whether the data type has a fixed precision scale */ boolean isFixedPrecisionScale(); /** * Whether the data type is nullable. * * @return Whether the data type is nullable */ boolean isNullable(); /** * Whether the data type is unsigned. * * @return Whether the data type is unsigned */ boolean isUnsigned(); /** * Whether the data type is user-defined. * * @return Whether the data type is user-defined */ boolean isUserDefined(); }